这篇文章接着上次的来,主要看逻辑运算符&短路逻辑运算符&赋值运算符&条件运算符&instanceof 运算符这五种运算符。
html
首先来看逻辑运算符。下表列出了逻辑运算符的基本运算,假设布尔变量A为真,变量B为假:java
操做符 | 描述 | 例子 |
---|---|---|
&& | 称为逻辑与运算符。当且仅当两个操做数都为真,条件才为真。 | (A && B)为假。 |
| | | 称为逻辑或操做符。若是任何两个操做数任何一个为真,条件为真。 | (A | | B)为真。 |
! | 称为逻辑非运算符。用来反转操做数的逻辑状态。若是条件为true,则逻辑非运算符将获得false。 | !(A && B)为真。 |
下面的简单示例程序演示了逻辑运算符。复制并粘贴下面的Java程序并保存为Test.java文件,而后编译并运行这个程序:express
public class Test {
public static void main(String[] args) {
boolean a = true;
boolean b = false;
System.out.println("a && b = " + (a&&b));
System.out.println("a || b = " + (a||b) );
System.out.println("!(a && b) = " + !(a && b));
}
}
spa
运行结果为:.net
a && b = false a || b = true !(a && b) = true
当使用与逻辑运算符时,在两个操做数都为true时,结果才为true,可是当获得第一个操做为false时,其结果就一定是false,这时候就不会再判断第二个操做了。code
public class LuoJi{
public static void main(String[] args){
int a = 5;//定义一个变量;
boolean b = (a<4)&&(a++<10);
System.out.println("使用短路逻辑运算符的结果为"+b);
System.out.println("a的结果为"+a);
}
}
htm
运行结果为:对象
使用短路逻辑运算符的结果为false a的结果为5
该程序使用到了短路逻辑运算符(&&),首先判断 a<4 的结果为 false,则 b 的结果一定是 false,因此再也不执行第二个操做 a++<10 的判断,因此 a 的值为 5。blog
而后来看赋值运算符。下面是Java语言支持的赋值运算符:接口
操做符 | 描述 | 例子 |
---|---|---|
= | 简单的赋值运算符,将右操做数的值赋给左侧操做数 | C = A + B将把A + B获得的值赋给C |
+ = | 加和赋值操做符,它把左操做数和右操做数相加赋值给左操做数 | C + = A等价于C = C + A |
- = | 减和赋值操做符,它把左操做数和右操做数相减赋值给左操做数 | C - = A等价于C = C - A |
* = | 乘和赋值操做符,它把左操做数和右操做数相乘赋值给左操做数 | C * = A等价于C = C * A |
/ = | 除和赋值操做符,它把左操做数和右操做数相除赋值给左操做数 | C / = A等价于C = C / A |
(%)= | 取模和赋值操做符,它把左操做数和右操做数取模后赋值给左操做数 | C%= A等价于C = C%A |
<< = | 左移位赋值运算符 | C << = 2等价于C = C << 2 |
>> = | 右移位赋值运算符 | C >> = 2等价于C = C >> 2 |
&= | 按位与赋值运算符 | C&= 2等价于C = C&2 |
^ = | 按位异或赋值操做符 | C ^ = 2等价于C = C ^ 2 |
| = | 按位或赋值操做符 | C | = 2等价于C = C | 2 |
下面的简单示例程序演示了赋值运算符。复制并粘贴下面的Java程序并保存为Test.java文件,而后编译并运行这个程序:
public class Test {
public static void main(String[] args) {
int a = 10;
int b = 20;
int c = 0;
c = a + b;
System.out.println("c = a + b = " + c );
c += a ;
System.out.println("c += a = " + c );
c -= a ;
System.out.println("c -= a = " + c );
c *= a ;
System.out.println("c *= a = " + c );
a = 10;
c = 15;
c /= a ;
System.out.println("c /= a = " + c );
a = 10;
c = 15;
c %= a ;
System.out.println("c %= a = " + c );
c <<= 2 ;
System.out.println("c <<= 2 = " + c );
c >>= 2 ;
System.out.println("c >>= 2 = " + c );
c >>= 2 ;
System.out.println("c >>= a = " + c );
c &= a ;
System.out.println("c &= 2 = " + c );
c ^= a ;
System.out.println("c ^= a = " + c );
c |= a ;
System.out.println("c |= a = " + c );
}
}
运行结果以下:
c = a + b = 30 c += a = 40 c -= a = 30 c *= a = 300 c /= a = 1 c %= a = 5 c <<= 2 = 20 c >>= 2 = 5 c >>= 2 = 1 c &= a = 0 c ^= a = 10 c |= a = 10
而后就是条件运算符(?:)。条件运算符也被称为三元运算符。该运算符有3个操做数,而且须要判断布尔表达式的值。该运算符的主要是决定哪一个值应该赋值给变量。
variable x = (expression) ? value if true : value if false
public class Test {
运行结果为:
Value of b is : 30 Value of b is : 20
再来就是instanceof 运算符。该运算符用于操做对象实例,检查该对象是不是一个特定类型(类类型或接口类型)。instanceof运算符使用格式以下:
( Object reference variable ) instanceof (class/interface type)
若是运算符左侧变量所指的对象,是操做符右侧类或接口(class/interface)的一个对象,那么结果为真。下面是一个例子:
String name = "James"; boolean result = name instanceof String; // 因为 name 是 String 类型,因此返回真
若是被比较的对象兼容于右侧类型,该运算符仍然返回true。看下面的例子:
true
当多个运算符出如今一个表达式中,谁先谁后呢?这就涉及到运算符的优先级别的问题。在一个多运算符的表达式中,运算符优先级不一样会致使最后得出的结果差异甚大。例如,(1+3)+(3+2)*2,这个表达式若是按加号最优先计算,答案就是 18,若是按照乘号最优先,答案则是 14。再如,x = 7 + 3 * 2;这里x获得13,而不是20,由于乘法运算符比加法运算符有较高的优先级,因此先计算3 * 2获得6,而后再加7。下表中具备最高优先级的运算符在的表的最上面,最低优先级的在表的底部:
类别 | 操做符 | 关联性 |
---|---|---|
后缀 | () [] . (点操做符) | 左到右 |
一元 | + + - !〜 | 从右到左 |
乘性 | * /% | 左到右 |
加性 | + - | 左到右 |
移位 | >> >>> << | 左到右 |
关系 | >> = << = | 左到右 |
相等 | == != | 左到右 |
按位与 | & | 左到右 |
按位异或 | ^ | 左到右 |
按位或 | | | 左到右 |
逻辑与 | && | 左到右 |
逻辑或 | | | | 左到右 |
条件 | ?: | 从右到左 |
赋值 | = + = - = * = / =%= >> = << =&= ^ = | = | 从右到左 |
逗号 | , | 左到右 |
Vehicle v2 = new Car(); // v2 是 Car 类型
v2 是 Car 类型,而不是 Vehicle 类型:
class Vehicle {} public class Car extends Vehicle { public static void main(String args[]){ Car c1 = new Car(); Vehicle v2 = new Car(); // v2 是 Car 类型 Vehicle v3 = new Vehicle(); //Car 是 Vehicle类型, Vehicle 不是 Car 类型 boolean result1 = c1 instanceof Vehicle; // true boolean result2 = v2 instanceof Car; // true boolean result3 = v2 instanceof Vehicle; // true boolean result4 = v3 instanceof Car; // false System.out.println(result1); System.out.println(result2); System.out.println(result3); System.out.println(result4); } }
子类是父类的类型,但父类不是子类的类型。子类的实例能够声明为父类型,但父类的实例不能声明为子类型:
class Vehicle {} public class Car extends Vehicle { public static void main(String args[]){ Vehicle v1 = new Vehicle(); //父类型 Vehicle v2 = new Car(); //子类的实例能够声明为父类型 Car c1 = new Car(); // 子类型 Car c2 = new Vehicle(); //这句会报错,父类型的实例不能声明为子类型 //Car(子类)是Vehicle(父类)类型, Vehicle(父类)不是Car(子类)类型 boolean result1 = c1 instanceof Vehicle; // true boolean result2 = c1 instanceof Car; // true boolean result3 = v1 instanceof Vehicle; // true boolean result4 = v1 instanceof Car; // false boolean result5 = v2 instanceof Vehicle; // true boolean result6 = v2 instanceof Car; // true System.out.println(result1); System.out.println(result2); System.out.println(result3); System.out.println(result4); System.out.println(result5); System.out.println(result6); } }
从执行结果来看,虽然 v2 被声明为了 Vehicle(父类),但它既是 instanceof Vehicle,又是 instanceof Car,因此 v2 实际上是 Car(子类),不然 v2 instanceof Car 应该为 false。