Як перетворити знак у рядок?


837

У мене є, charі мені потрібно String. Як перетворити з одного на інший?


187
Захищений? Чому я б задав таке легке запитання? Оскільки Google не має дійсно очевидних результатів пошуку для цього питання. Вказавши це, ми змінимо це.
Ландон Кун

45
я повністю згоден з вашою думкою. Я проголосував за це, щоб позбутися негативного голосу. Я твердо вірю в те, що полегшити такі теми Google, як ця, для всіх. =)
prolink007

4
Чи включало ваше дослідження читання документації класу String?
DJClayworth

12
@DJClayworth На більшість запитань SO можна відповісти за допомогою RTFM, але це не дуже корисно. Чому б не дозволити людям, які знайшли питання, підкріпити це і не пустити справи на свій шлях?
beldaz

10
@PaulBellora Тільки той StackOverflow став першою зупинкою для досліджень. Якщо в перших 10 результатах Google є посилання на StackOverlfow, я перебуваю тут.
Мартін

Відповіді:


642

Можна використовувати 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), що дозволяє уникнути копіювання масиву.


Я думаю, що ярлик складається до:new StringBuilder("").append('s').toString();
Бінкана Заробітна плата

@BinkanSalaryman, використовуючи javac 1.8.0_51-b16, а потім javap для декомпіляції, я бачу у відповіді виклики конструктора / методу. Що ви використовуєте?
Пол Беллора

237

Приємне запитання. У мене є наступні п'ять 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();

// #5
   // Although this method seems very simple, 
   // this is less efficient because the concatenation
   // expands to new StringBuilder().append(x).append("").toString();
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)викликає наступний приватний конструктор пакунків.

String(char[] value, boolean share) {
    // assert share : "unshared not supported";
    this.value = value;
}

Вихідний код з String.javaв Java 8 вихідного коду

Отже, String.valueOf(char)здається, це найбільш ефективний спосіб перетворення charв пам'ять і швидкість String.

  1. Як перетворити примітивний char в String на Java
  2. Як перетворити Char в String в Java за допомогою прикладу

50

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

хтось це перевірив?
Лукас Ноетзольд

34

Використовуйте такий Character.toString()метод, як:

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

33

Використовуйте будь-яке з наступного:

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

17

Як зазначає @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оптимізацією. Про це можна прочитати тут .



4

У нас є різні способи перетворення 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класу, який насправді є кращим, коли ми робимо конкатенацію в циклі.


4

Ось кілька методів, не в конкретному порядку:

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

2

Я перетворюю масив Char в String

Char[] CharArray={ 'A', 'B', 'C'};
String text = String.copyValueOf(CharArray);

Це не дає відповіді на запитання. Щоб критикувати або вимагати роз'яснення у автора, залиште коментар під їх дописом. - З огляду
pczeus

Я перетворюю масив Char на String @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;
                }
            }
        }});
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.