推薦學習:《》
運運算元 | 含義 |
---|---|
+ | 求和 |
- | 相減 |
* | 乘積 |
/ | 商 |
% | 求餘數(求模) |
++ | 自加一 |
– | 自減一 |
當++出現在變數前,會先自加一
,在做賦值運算
int x = 100; int y = ++x; 步驟: ② ① System.out.println(x); // 101 System.out.println(y); // 101
當++出現在變數後,會先做賦值運算
,再自加1
int m = 20; int n = m++; 步驟: ① ② System.out.println(n); // 20 System.out.println(m); // 21
int c = 90; System.out.println(c++); // 傳,這個「傳」在這裡有一個隱形的賦值運算。90 // 把上面程式碼拆解開 //int temp = c++; //System.out.println(temp); int d = 80; System.out.println(++d); //81 // 拆解 //int temp2 = ++d; //System.out.println(temp2);
當–出現在變數前,會先自減一
,在做賦值運算
當–出現在變數後,會先做賦值運算
,再自減1
注意:
對於++運運算元來說:
1.可以出現在變數前,也可以出現在變數後。
2.不管出現在變數前還是後,總之++執行結束之後,變數的值一定會自加1。
運運算元 | 含義 |
---|---|
> | 大於 |
>= | 大於等於 |
< | 小於 |
<= | 小於等於 |
== | 等於 |
!= | 不等於 |
注意:所有的關係運算子的運算結果都是布林型別,不是true就是false,不可能是其他值。
運運算元 | 含義 | 結果 |
---|---|---|
& | 邏輯與(可以翻譯成並且) | 兩邊都是true,結果才是true |
│ | 邏輯或(可以翻譯成或者) | 有一邊是true,結果就是true |
! | 邏輯非(取反) | !true = false、!false = true |
&& | 短路與 | 兩邊都是true,結果才是true |
││ | 短路或 | 有一邊是true,結果就是true |
首先這兩個運運算元的運算結果沒有任何區別,完全相同。
只不過「短路與&&」會發生短路
現象。
int x = 10; int y = 11; System.out.println(x > y & x > y++); //false // 通過這個測試得出:x > y++ 這個表示式執行了。 System.out.println(y); // 12 //測試短路與&& int m = 10; int n = 11; // 使用短路與&&的時候,當左邊的表示式為false的時候,右邊的表示式不執行 // 這種現象被稱為短路。 System.out.println(m > n && m > n++); System.out.println(n); // 11
右邊表示式不執行,這種現象叫做短路現象。
從效率方面來說,&&比&的效率高一些。
因為邏輯與&不管第一個表示式結果是什麼,第二個表示式一定會執行。
以後的開發中,短路與&&和邏輯與還是需要同時並存的。
大部分情況下都建議使用短路與&&只有當既需要左邊表示式執行,又需要右邊表示式執行的時候,才會選擇邏輯與&。
跟短路與類似
int x = 10; int y = 11; System.out.println(x < y | x > y++); //teur // 通過這個測試得出:x > y++ 這個表示式執行了。 System.out.println(y); // 12 //測試短路或|| int m = 10; int n = 11; // 使用短路或||的時候,當左邊的表示式為true的時候,右邊的表示式不執行 // 這種現象被稱為短路。 System.out.println(m < n || m > n++); System.out.println(n); // 11
false
的時候,右邊的表示式不執行true
的時候,右邊的表示式不執行注意:邏輯運運算元兩邊要求都是布林型別,並且最終的運算結果也是布林型別。
運運算元 | 含義 |
---|---|
= | 賦值 |
+= | 加等(原先的基礎上加上/追加這個數) |
-= | 減等(同理) |
*= | 乘等(同理) |
/= | 除等(同理) |
%= | 模等(同理) |
注:除了第一個是賦值運運算元,其他都死拓展賦值運運算元!!
使用擴充套件賦值運運算元
的時候,永遠都不會改變
運算結果型別。
int m = 10; m += 10; 類似於 m = m + 1;------->注意是類似!!!! 實際不同: i = i + 10; 和 i += 10;一樣嗎? byte i = 10; i += 10;----->沒報錯 其實 x += 1 等同於:x = (byte)(x + 1); i = i + 10;---->錯誤: 不相容的型別: 從int轉換到byte可能會有損失 編譯器檢測到x + 1是int型別,int型別不可以直接賦值給byte型別的變數x! 詳見Java型別轉換的時候需要遵循的規則第六點 i += 190; // i = (byte)(i + 190); System.out.println(i); // 44 (當然會自動損失精度了。)
布林表示式 ? 表示式1 : 表示式2
布林表示式的結果為true
時,表示式1
的執行結果作為整個表示式的結果。
布林表示式的結果為false
時,表示式2
的執行結果作為整個表示式的結果。
好玩點:
char a = true ? '男' : "女"; string a1 = true ? '男' : "女"; 以上兩個都報錯。 //下面可以 String s = ""; s += true ? '男' : "女";
求和
字串拼接
數位型別
的時候,求和。任意一邊
」是字串型別
,那麼這個+會進行字串拼接操作。int a = 100; int b = 200; // 這裡的 + 兩邊都是數位,所以加法運算 int c = a + b; System.out.println(a + "+" + b + " = " + a + b);//100+200=100200 System.out.println(a + "+" + b + " = " + (a + b));//100+200=300
注:遵循「自左向右
」的順序依次執行。(除非額外新增了小括號,小括號的優先順序高)
推薦學習:《》
以上就是詳細講解Java運運算元(總結分享)的詳細內容,更多請關注TW511.COM其它相關文章!