首先看一下三元运算符的格式
[条件语句] ? [表达式1] : [表达式2]
其中如条件语句为真执行表达式1,否则执行表达式2.简单的例子就不举了,来点其它的。在JDK1.5以前的版本中,表达式1和表达式2都要求是相同的类型,比如都是String或者char之类的,在JDK1.5以后,有了自动拆箱和装箱的原因,两者只要其中一种或者两者都能被拆箱即可,比如表达式1为Integer,而表达式2为int类型的,比如如下
1 int a = 1; 2 Integer b = 2; 3 boolean c = ture; 4 int d = c ? b : a;
还有个需要注意的是,如果表达式1和表达式2的类型不相同,那么他们需要对交集类型的自动参考转换。例如如下这段代码
1 String str = "abc"; 2 StringBuilder strbu = new StringBuilder("def"); 3 boolean boo = true; 4 CharSequence cs = boo ? str : strbu;
因为String和StringBuilder都实现了CharSequence这个接口。
确定条件表达式结果类型的规则的核心是以下3点:
1 如果表达式1和表达式2操作数具有相同的类型,那么它就是条件表达式的类型。
2 如果一个表达式的类型是byte、short、char类型的,而另外一个是int类型的常量表达式,且它的值可以用类型byte、short、char三者之一表示的,那么条件表达式的类型就是三者之一
3 否则,将对操作数类型进行二进制数字提升,而条件表达式的类型就是第二个和第三个操作数被提升之后的类型
以上的三点可以用如下的代码来帮助理解:
1 char ch = 'a'; 2 int num = 0 ; 3 boolean bool = true; 4 System.out.print( bool ? ch : 0); //这里不是 bool ? ch : num ,那样会打印两个97 5 System.out.print( !bool ? num : ch);
这段代码打印的是 a97 。很显然,第二点的规则应用到第一个打印上了,返回的是char,第三点的规则应用到第二个打印上了,返回的是int 。但是谁会在乎这个顺序导致的打印结果,所以为了避免不必要的麻烦,很显然显式强制类型转换是个很不错的选择 -_-
1 char ch = 'a'; 2 int num = 0 ; 3 boolean bool = true; 4 System.out.print( bool ? (char)ch : (char)0); 5 System.out.print( !bool ? (int)num : (int)ch);
还有值得注意的是 表达式1 和 表达式2 不一定非得是数据类型,还可以是自己定义的方法,只要方法有返回值就行。例如
1 static int test1(int i) { 2 i += 1; 3 return i; 4 5 } 6 7 static int test2(int i) { 8 i += 2; 9 return i; 10 } 11 12 public static void ternary() { 13 boolean boo = false; 14 int c = boo ? test1(1) : test2(2); 15 }
以上就是个人的一点小心得~~有些内容可以参考条件表达式规范[JLS 15.25]