У меня есть char
, и мне нужен String
. Как конвертировать из одного в другой?
Как преобразовать char в строку?
Ответ 1
Вы можете использовать Character.toString(char)
. Обратите внимание, что этот метод просто возвращает вызов String.valueOf(char)
, который также работает.
Как отмечали другие, конкатенация строк также работает как ярлык:
String s = "" + 's';
Но это скомпилируется до:
String s = new StringBuilder().append("").append('s').toString();
который менее эффективен, поскольку StringBuilder
поддерживается char[]
(перераспределяется StringBuilder()
до 16
), только для того, чтобы этот массив был скопирован с помощью результирующего String
.
String.valueOf(char)
"попадает в черный ход", обертывая char
в одноэлементном массиве и передавая его частному конструктору пакета String(char[], boolean)
, что позволяет избежать копирования массива.
Ответ 2
Хороший вопрос. У меня есть следующие five 6 методов для этого.
1. String stringValueOf = String.valueOf('c'); // most efficient
2. String stringValueOfCharArray = String.valueOf(new char[]{x});
3. String characterToString = Character.toString('c');
4. String characterObjectToString = new Character('c').toString();
// Although this method seems very simple,
// this is less efficient because the concatenation
// expands to new StringBuilder().append(x).append("").toString();
5. String concatBlankString = 'c' + "";
6. String fromCharArray = new String(new char[]{x});
Примечание: Character.toString(char) возвращает String. valueOf (char). Таким образом, обе они одинаковы.
String.valueOf(char[] value)
вызывает new String(char[] value)
, который, в свою очередь, устанавливает массив value
char.
public String(char value[]) {
this.value = Arrays.copyOf(value, value.length);
}
С другой стороны, String.valueOf(char value)
вызывает следующий конструктор package private.
String(char[] value, boolean share) {
// assert share : "unshared not supported";
this.value = value;
}
Исходный код из String.java
в Java 8 исходный код
Следовательно,
String.valueOf(char)
представляется наиболее эффективным методом с точки зрения как памяти, так и скорости для преобразованияchar
вString
.
Ответ 3
Ниже приведены различные способы преобразования в char c в String s (в порядке убывания скорости и эффективности)
char c = 'a';
String s = String.valueOf(c); // fastest + memory efficient
String s = Character.toString(c);
String s = new String(new char[]{c});
String s = String.valueOf(new char[]{c});
String s = new Character(c).toString();
String s = "" + c; // slowest + memory inefficient
Ответ 4
Используйте любое из следующих действий:
String str = String.valueOf('c');
String str = Character.toString('c');
String str = 'c' + "";
Ответ 5
Используйте метод Character.toString() следующим образом
char c = 'l';
String s = Character.toString(c);
Ответ 6
Попробуйте следующее: Character.toString(aChar)
или просто следующее: aChar + ""
Ответ 7
Как указано в @WarFox - существует 6 методов преобразования char в строку. Тем не менее, самый быстрый из них был бы через конкатенацию, несмотря на ответы выше, в которых говорится, что это String.valueOf
. Вот пример, который доказывает, что:
@BenchmarkMode(Mode.Throughput)
@Fork(1)
@State(Scope.Thread)
@Warmup(iterations = 10, time = 1, batchSize = 1000, timeUnit = TimeUnit.SECONDS)
@Measurement(iterations = 10, time = 1, batchSize = 1000, timeUnit = TimeUnit.SECONDS)
public class CharToStringConversion {
private char c = 'c';
@Benchmark
public String stringValueOf() {
return String.valueOf(c);
}
@Benchmark
public String stringValueOfCharArray() {
return String.valueOf(new char[]{c});
}
@Benchmark
public String characterToString() {
return Character.toString(c);
}
@Benchmark
public String characterObjectToString() {
return new Character(c).toString();
}
@Benchmark
public String concatBlankStringPre() {
return c + "";
}
@Benchmark
public String concatBlankStringPost() {
return "" + c;
}
@Benchmark
public String fromCharArray() {
return new String(new char[]{c});
}
}
И результат:
Benchmark Mode Cnt Score Error Units
CharToStringConversion.characterObjectToString thrpt 10 82132.021 ± 6841.497 ops/s
CharToStringConversion.characterToString thrpt 10 118232.069 ± 8242.847 ops/s
CharToStringConversion.concatBlankStringPost thrpt 10 136960.733 ± 9779.938 ops/s
CharToStringConversion.concatBlankStringPre thrpt 10 137244.446 ± 9113.373 ops/s
CharToStringConversion.fromCharArray thrpt 10 85464.842 ± 3127.211 ops/s
CharToStringConversion.stringValueOf thrpt 10 119281.976 ± 7053.832 ops/s
CharToStringConversion.stringValueOfCharArray thrpt 10 86563.837 ± 6436.527 ops/s
Как вы можете видеть, самым быстрым будет c + ""
или "" + c
;
VM version: JDK 1.8.0_131, VM 25.131-b11
Эта разница в производительности обусловлена оптимизацией -XX:+OptimizeStringConcat
. Вы можете прочитать об этом здесь.
Ответ 8
У нас есть различные способы преобразования a char
в String
. Один способ состоит в использовании статического метода toString()
в классе Character
:
char ch = 'I';
String str1 = Character.toString(ch);
Фактически этот метод toString
использует метод valueOf
из класса String
, который использует массив char:
public static String toString(char c) {
return String.valueOf(c);
}
Так что второй способ использовать это напрямую:
String str2 = String.valueOf(ch);
Этот метод valueOf
в классе String
использует массив char:
public static String valueOf(char c) {
char data[] = {c};
return new String(data, true);
}
Таким образом, третий способ состоит в использовании анонимного массива для обертывания одного символа, а затем передачи его в конструктор String
:
String str4 = new String(new char[]{ch});
Четвертый способ заключается в использовании конкатенации:
String str3 = "" + ch;
Это фактически будет использовать метод append
из класса StringBuilder
, который фактически является предпочтительным, когда мы делаем конкатенацию в цикле.
Ответ 9
Вот несколько методов, в определенном порядке:
char c = 'c';
String s = Character.toString(c); // Most efficient way
s = new Character(c).toString(); // Same as above except new Character objects needs to be garbage-collected
s = c + ""; // Least efficient and most memory-inefficient, but common amongst beginners because of its simplicity
s = String.valueOf(c); // Also quite common
s = String.format("%c", c); // Not common
Formatter formatter = new Formatter();
s = formatter.format("%c", c).toString(); // Same as above
formatter.close();
Ответ 10
Я пробовал предложения, но в конечном итоге реализовал его следующим образом
editView.setFilters(new InputFilter[]{new InputFilter()
{
@Override
public CharSequence filter(CharSequence source, int start, int end,
Spanned dest, int dstart, int dend)
{
String prefix = "http://";
//make sure our prefix is visible
String destination = dest.toString();
//Check If we already have our prefix - make sure it doesn't
//get deleted
if (destination.startsWith(prefix) && (dstart <= prefix.length() - 1))
{
//Yep - our prefix gets modified - try preventing it.
int newEnd = (dend >= prefix.length()) ? dend : prefix.length();
SpannableStringBuilder builder = new SpannableStringBuilder(
destination.substring(dstart, newEnd));
builder.append(source);
if (source instanceof Spanned)
{
TextUtils.copySpansFrom(
(Spanned) source, 0, source.length(), null, builder, newEnd);
}
return builder;
}
else
{
//Accept original replacement (by returning null)
return null;
}
}
}});
Ответ 11
Я преобразовываю Char Array в String
Char[] CharArray={ 'A', 'B', 'C'};
String text = String.copyValueOf(CharArray);