如何将字符转换为string?

我有一个char ,我需要一个String 。 我如何从一个转换到另一个?

你可以使用Character.toString(char) 。 请注意,此方法只是返回一个调用String.valueOf(char) ,这也是可行的。

正如其他人所指出的,string连接也是一个捷径:

 String s = "" + 's'; 

但是这个汇编到:

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

这是因为StringBuilderchar[] (通过StringBuilder()重新分配到16 )来支持,因此StringBuilder()仅由该String产生防御性复制。

String.valueOf(char)通过将char包装到一个单一元素的数组中并将其传递给包私有构造函数String(char[], boolean)来避免数组拷贝。

很好的问题。 我有以下五种方法来做到这一点。

 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)调用下面的包私有构造函数。

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

Java 8源代码中 String.java 源代码

因此String.valueOf(char)似乎是最有效的方法,就内存和速度而言,将char转换为String

  1. 如何将原始字符转换为Java中的string
  2. 如何使用示例在Java中将Char转换为String

以下是将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 

使用以下任何一项:

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

像这样使用Character.toString()方法

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

试试这个: Character.toString(aChar)或者只是这个: aChar + ""

我们有各种方法将char转换为String一种方法是在Character类中使用静态方法toString()

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

实际上,这个toString方法内部使用chartypes的String类中的valueOf方法:

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

所以第二种方法是直接使用这个:

 String str2 = String.valueOf(ch); 

String类中的这个valueOf方法使用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; 

这实际上会使用StringBuilder类中的append方法,这实际上是我们在循环中进行连接时首选的方法。

这里有几个方法,没有特别的顺序:

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

正如@WarFox所说 – 有6种方法将char转换为string。 然而,尽pipe上面的回答声明它是String.valueOf ,最快的一个将通过串联。 这是基准certificate:

 @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优化。 你可以在这里阅读。

我已经尝试了这些build议,但最终如下实现它

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

我将Char数组转换为string

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