Как преобразовать символ в строку?

629

У меня есть char, и мне нужен String. Как конвертировать из одного в другой?

  • 167
    Downvoted? Зачем мне задавать такой простой вопрос? Потому что у Google нет действительно очевидного результата поиска по этому вопросу. Поместив это здесь, мы изменим это.
  • 39
    Я абсолютно согласен с твоим мнением. Я проголосовал за это, чтобы избавиться от отрицательного голоса. Я твердо верю в то, чтобы сделать такие темы для гуглов проще для всех. знак равно
Показать ещё 5 комментариев
Теги:
string
type-conversion
char

11 ответов

523

Вы можете использовать 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), что позволяет избежать копирования массива.

  • 0
    Я думаю, что ярлык компилируется в: new StringBuilder("").append('s').toString();
  • 0
    @BinkanSalaryman, использующий javac 1.8.0_51-b16 и затем javap для декомпиляции, я вижу вызовы конструктора / метода, которые у меня есть в ответе. Что вы используете?
181

Хороший вопрос. У меня есть следующие 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.

35

Ниже приведены различные способы преобразования в 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
30

Используйте любое из следующих действий:

String str = String.valueOf('c');
String str = Character.toString('c');
String str = 'c' + "";
16

Используйте метод Character.toString() следующим образом

char c = 'l';
String s = Character.toString(c);
14

Попробуйте следующее: Character.toString(aChar) или просто следующее: aChar + ""

  • 2
    Почему бы не метод toString () на самом char?
  • 7
    Потому что в Java нельзя вызывать методы для базовых типов, таких как char ...
4

Как указано в @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. Вы можете прочитать об этом здесь.

3

Вот несколько методов, в определенном порядке:

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();
3

У нас есть различные способы преобразования 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, который фактически является предпочтительным, когда мы делаем конкатенацию в цикле.

0

Я преобразовываю Char Array в String

Char[] CharArray={ 'A', 'B', 'C'};
String text = String.copyValueOf(CharArray);
  • 0
    Это не дает ответа на вопрос. Чтобы критиковать или запросить разъяснения у автора, оставьте комментарий под своим постом. - Из обзора
  • 0
    Я конвертирую массив символов в строку @pczeus
0

Я пробовал предложения, но в конечном итоге реализовал его следующим образом

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;
                }
            }
        }});

Ещё вопросы

Сообщество Overcoder
Наверх
Меню