這篇文章接着上次的來,主要看邏輯運算符&短路邏輯運算符&賦值運算符&條件運算符&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。