Vin*_*hwa 8 java string casting boolean string-concatenation
这是如何运作的?我似乎无法找到答案.
boolean bool=true;
System.out.println("the value of bool is : " + true);
//or
System.out.println("the value of bool is : " + bool);
Run Code Online (Sandbox Code Playgroud)
toString()
或String.valueOf()
以某种方式参与?NPE*_*NPE 16
精确的规则在Java语言规范§5.1.11中有详细说明.字符串转换
根据这些规则,"str" + bool
相当于:
"str" + new Boolean(bool).toString()
Run Code Online (Sandbox Code Playgroud)
也就是说,编译器在如何评估整体表达式方面具有相当大的余地.来自JLS§15.18.1.字符串连接运算符+:
实现可以选择在一个步骤中执行转换和连接,以避免创建然后丢弃中间String对象.为了提高重复字符串连接的性能,Java编译器可以使用
StringBuffer
该类或类似技术来减少String
通过表达式求值创建的中间对象的数量.对于基本类型,实现还可以通过直接从基本类型转换为字符串来优化包装对象的创建.
例如,我的编译器如下:
boolean bool = true;
System.out.println("the value of bool is : " + bool);
Run Code Online (Sandbox Code Playgroud)
完全等同于:
boolean bool = true;
System.out.println(new StringBuilder("the value of bool is : ").append(bool).toString());
Run Code Online (Sandbox Code Playgroud)
它们导致相同的字节码:
Code:
0: iconst_1
1: istore_1
2: getstatic #59 // Field java/lang/System.out:Ljava/io/PrintStream;
5: new #166 // class java/lang/StringBuilder
8: dup
9: ldc #168 // String the value of bool is :
11: invokespecial #170 // Method java/lang/StringBuilder."<init>":(Ljava/lang/String;)V
14: iload_1
15: invokevirtual #172 // Method java/lang/StringBuilder.append:(Z)Ljava/lang/StringBuilder;
18: invokevirtual #176 // Method java/lang/StringBuilder.toString:()Ljava/lang/String;
21: invokevirtual #69 // Method java/io/PrintStream.println:(Ljava/lang/String;)V
24: return
Run Code Online (Sandbox Code Playgroud)