我有一个char
,我需要一个String
。如何从一个转换为另一个?
我有一个char
,我需要一个String
。如何从一个转换为另一个?
Answers:
您可以使用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
in 包装到单个元素数组中并将其传递给package private构造函数来“进入后门” String(char[], boolean)
,这避免了数组复制。
new StringBuilder("").append('s').toString();
好问题。我有以下五种 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
。
以下是将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
正如@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
优化。你可以在这里阅读。
试试这个:Character.toString(aChar)
或者只是这个:aChar + ""
我们有多种方法可以将转换char
为String
。一种方法是toString()
在Character
类中使用静态方法:
char ch = 'I';
String str1 = Character.toString(ch);
实际上,此toString
方法在内部利用了使用char数组的类中的valueOf
方法String
:
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
当我们在循环中进行串联时,这实际上是首选方法。
以下是一些方法,不分先后顺序:
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();
我尝试了这些建议,但最终如下实施
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;
}
}
}});