Java探究心得之三元运算符

首先看一下三元运算符的格式

  [条件语句] ? [表达式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]

posted @ 2012-09-03 01:38  Lowp  阅读(28560)  评论(3编辑  收藏  举报