Comment convertir un char en chaîne de caractères?

j'ai un char et j'ai besoin d'un String . Comment puis-je convertir de l'un à l'autre?

721
demandé sur Rakete1111 2011-11-17 22:37:19

11 réponses

vous pouvez utiliser Character.toString(char) . Notez que cette méthode renvoie simplement un appel à String.valueOf(char) , ce qui fonctionne aussi.

comme d'autres l'ont noté, la concaténation de chaîne fonctionne aussi comme un raccourci:

String s = "" + 's';

Mais cette compile:

String s = new StringBuilder().append("").append('s').toString();

, ce qui est moins efficace parce que le StringBuilder est soutenu par un char[] (sur-attribué par StringBuilder() à 16 ), seulement pour que ce tableau soit copié défensivement par le résultat String .

String.valueOf(char) "passe par la porte arrière" en enveloppant le char dans un tableau à un seul élément et en le passant au constructeur privé du paquet String(char[], boolean) , ce qui évite la copie du tableau.

580
répondu Paul Bellora 2015-03-15 04:29:38

bonne question. J'ai des 5 6 méthodes pour le faire.

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

Note: Caractère.toString (char) renvoie chaîne.valueOf (char) . Donc les deux sont effectivement identiques.

String.valueOf(char[] value) invoque new String(char[] value) , qui à son tour met en place le tableau de caractères value .

public String(char value[]) {
    this.value = Arrays.copyOf(value, value.length);
}

sur le d'autre part String.valueOf(char value) invoque le suivant package private constructor.

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

code Source String.java dans Java 8 code source

donc String.valueOf(char) semble être la méthode la plus efficace, en termes de mémoire et de vitesse, pour convertir char en String .

  1. comment convertir char primitif en chaîne de caractères en Java
  2. comment convertir Char en chaîne de caractères en Java avec L'exemple
211
répondu WarFox 2017-01-30 09:42:46

ci-dessous, il y a plusieurs façons de convertir les caractères en chaîne s (par ordre décroissant de vitesse et d'efficacité)

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
41
répondu sactiw 2016-02-08 11:38:05

utiliser l'un des éléments suivants:

String str = String.valueOf('c');
String str = Character.toString('c');
String str = 'c' + "";
31
répondu Wayne Burkett 2011-11-17 18:42:19

utilisez la méthode Character.toString() comme suit:

char mChar = 'l';
String s = Character.toString(mChar);
18
répondu Tom 2018-03-30 09:14:25

essayez ceci: Character.toString(aChar) ou juste ceci: aChar + ""

15
répondu Óscar López 2011-11-17 18:39:09

comme @WarFox a déclaré - Il y a 6 méthodes pour convertir char en chaîne. Toutefois, le plus rapide serait celui de la concaténation, malgré les réponses ci-dessus indiquant qu'il s'agit de String.valueOf . Voici benchmark qui prouve que:

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

et résultat:

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

Comme vous pouvez le voir, le plus rapide serait c + "" ou "" + c ;

VM version: JDK 1.8.0_131, VM 25.131-b11

cette différence de performance est due à -XX:+OptimizeStringConcat optimisation. Vous pouvez le lire ici .

8
répondu Dmitriy Dumanskiy 2017-06-11 15:09:19

nous avons plusieurs façons de convertir un char en String . Un façon est de rendre l'utilisation de la méthode statique toString() dans Character classe:

char ch = 'I'; 
String str1 = Character.toString(ch);

en fait, cette méthode toString utilise en interne la méthode valueOf de la classe String qui utilise un tableau de caractères:

public static String toString(char c) {
    return String.valueOf(c);
}

So second utilisation directe:

String str2 = String.valueOf(ch);

cette "méthode 1519110920" dans la classe String utilise un tableau de caractères:

public static String valueOf(char c) {
        char data[] = {c};
        return new String(data, true);
}

ainsi la troisième manière est de faire usage d'un tableau anonyme pour envelopper un seul caractère et puis le passer à String constructeur:

String str4 = new String(new char[]{ch});

la quatrième est de faire usage de la concaténation:

String str3 = "" + ch;

ce sera effectivement utiliser de la méthode append de la classe StringBuilder qui est en fait préférable lorsque nous faisons la concaténation dans une boucle.

4
répondu i_am_zero 2015-08-24 04:19:27

voici quelques méthodes, sans ordre particulier:

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();
4
répondu HyperNeutrino 2016-02-06 19:37:56

je convertis Char Array en String

Char[] CharArray={ 'A', 'B', 'C'};
String text = String.copyValueOf(CharArray);
2
répondu Shivanandam Sirmarigari 2017-01-27 14:22:21

j'ai essayé les suggestions mais j'ai fini par les mettre en œuvre comme suit

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;
                }
            }
        }});
0
répondu zmicer 2016-09-16 13:01:23