您可以使用String.valueOf
builder.indexOf(String.valueOf(c));
这个方法有很多好处.
>干净的代码
> String.valueOf使用char []从传递的char likechar data [] = {c};中创建String对象.因此不需要其他操作.
2实际上是一个微优化,我将始终选择选项1,即“干净代码”.
值得一提的是,这是串联版本生成的字节码:
new #2; //class java/lang/StringBuilder
dup
invokespecial #6; //Method java/lang/StringBuilder."":()V
aload_1
invokevirtual #7; //Method java/lang/StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc #8; //String
invokevirtual #9; //Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual #10; //Method java/lang/StringBuilder.toString:()Ljava/lang/String;
invokevirtual #11; //Method java/lang/StringBuilder.indexOf:(Ljava/lang/String;)I
如您所见,它将创建第二个StringBuilder,执行两次追加调用,然后执行toString.相反,这是String.valueOf版本:
aload_0
aload_1
invokestatic #12; //Method java/lang/String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokevirtual #11; //Method java/lang/StringBuilder.indexOf:(Ljava/lang/String;)I
这只是将角色(已经自动装箱成一个字符)交给了String.valueOf.那怎么办?让我们看一下JDK源代码:
public static String valueOf(char c) {
char data[] = {c};
return new String(0, 1, data);
}
因此,它将创建一个新的单字符数组,并将其直接传递给String构造函数.很可能会更有效率.
但是,这又可能是微观优化. String.valueOf调用使代码更清晰,这是最主要的.