帶你盤點Java的五種運算符
1、算術運算符
算術運算符的符號通常為:加(+)、減(-)、乘(*)、除(/)、取餘(%)、自增(++)、自減(–)。
使用int類型的變量和int類型的變量做除法,得到的結果還是int類型;
使用double類型的常量和 int類型的常量做除法,會得到double類型的結果;在使用強制類型double轉換可以得到double類型
System.out.println(7 / 2);//3.0 System.out.println((double)(7 / 2)); // 3.0 System.out.println((double)7 / 2); // 3.5
既然存在除法,那麼對於除0這個特殊的數,Java的程序是怎麼處理的呢,是否都是異常的報錯呢?我們可以執行試一下
// 產生異常:java.lang.ArithmeticException: / by zero int i = 123 / 0; System.out.println(i); // 產生異常:java.lang.ArithmeticException: / by zero int j = 0 / 0; System.out.println(j); double k = 123.45 / 2; System.out.println(k); // 61.725 double x = 123.45 / 0; System.out.println(x); // Infinity(正無窮大) double y = -123.45 / 0; System.out.println(y); // -Infinity(負無窮大) double m = 0.0 / 0; System.out.println(m); // NaN(Not a number 不是一個數) double n = -0.0 / 0; System.out.println(n); // NaN(Not a number 不是一個數) float x = 123.45F / 0; System.out.println(x); // Infinity(正無窮大) float y = -123.45F / 0; System.out.println(y); // -Infinity(負無窮大) float m = 0.0F / 0; System.out.println(m); // NaN(Not a number 不是一個數) float n = -0.0F / 0; System.out.println(n); // NaN(Not a number 不是一個數) //產生異常:java.lang.ArithmeticException: / by zero int x = 11 % 0; System.out.println(x); double y = 11.0 % 0; System.out.println(y); // NaN
自增運算符
單獨使用自增運算符:不論++放在需要自增的變量的前面還是後面,都會在操作後讓變量的值自增1
非單獨使用自增運算符:int j = i++; // i: 3 j: 2(一上來先把i的值賦值給j,然後i自己做自增(先賦值再自增));int j = ++i; // i: 3 j: 3(上來先i自己做自增,然後把i的值(自增後的值)賦值給j(先自增再賦值));
這裡附加一個練習題:
int i = 2; int j = 3; j = i++ + ++i+i*6;
最後j是多少?(結果是:30)
2、賦值運算符
賦值運算符:=、+=、-=、*=、/=、%=
這個沒什麼說的隻是進行賦值的操作,隻是要註意對於非默認數據類型的數據,使用帶有算術運算符的賦值運算符時,會自動進行強制類型轉換,例如:
byte j = 5;j += 6; // 下句等價於上句 j = (byte) (j + 6);
3、比較運算符
比較運算符:==、!=、>、<、>=、<=;Java中使用 == 表示相等(內容相等)
4、邏輯運算符
邏輯運算符:&
、|
、!
、^
、&&
、||
&:邏輯與,有一個是false得到的結果就是false
|:邏輯或,有一個是true得到的結果就是true
!:邏輯非,顛倒黑白
^:邏輯異或,類似吸鐵石(真假為真,真真為假,假假為假)
&&:邏輯與,如果參與運算的第一個變量或表達式為false,得到的結果就是false,其他的變量或表達式就不去執行;如果多個邏輯與參與運算,以此類推;
||:邏輯或,如果參與運算的第一個變量或表達式為true,得到的結果就是true,其他的變量或表達式就不去執行;如果多個邏輯與參與運算,以此類推;
&和&&區別:&&具有短路的操作,比如第一個表達式是false時,是不會執行第二個表達式(if(s!=null&&s.equal(“”))),如果s是null的話使用&就會報錯;&可以可以用在位運算符中。
練習題:
int i = 2; int j = 3; System.out.println((++i == 2) && (j++ == 3));
問:最終i 和 j 的值是多少?(i為3,j為3)
int i = 2; int j = 3; System.out.println((++i == 2) & (j++ == 3));
問:最終i 和 j 的值是多少?(i為3,j為4)
5、位運算符
位運算符:&
、|
、~
、^
、>>
、>>>
、<<
規則:(在二進制中)操作的是補碼
&:位與,進行操作的兩個數的同一位上,有一個是0,該位運算的結果就是0
|:位或,進行操作的兩個數的同一位上,有一個是1,該位運算的結果就是1
~:位非,進行操作的數按位取反
^:位異或,進行操作的兩個數的同一位上,兩個相同為0,兩個不同為1(規律:一個數連續兩次和另一個數做位異或運算,得到其本身的值)
System.out.println(2 & 3); // 2 System.out.println(2 | 3); // 3 System.out.println(~2); // -3 System.out.println(2 ^ 3); // 1 System.out.println(2 ^ 3 ^ 3); // 2 /* * 2:0000 0010 * 3:0000 0011 * * 2 * 原碼:0000 0000 0000 0000 0000 0000 0000 0010 * 反碼:0000 0000 0000 0000 0000 0000 0000 0010 * 補碼:0000 0000 0000 0000 0000 0000 0000 0010 * * ~2 * 補碼:1111 1111 1111 1111 1111 1111 1111 1101 * 反碼:1111 1111 1111 1111 1111 1111 1111 1100 * 原碼:1000 0000 0000 0000 0000 0000 0000 0011 */
<<:左移,左邊的高位刪除,右邊的低位補0
>>:右移,因為左側的最高位是符號位,所以要區分是0還是1;左側的最高位是0,左側補0;左側的最高位是1,左側補1 >>>:無符號右移,不論左側的最高位是0還是1,左側補0
System.out.println(2 << 1); // 4 System.out.println(2 >> 1); // 1 System.out.println(-2 >> 1); // -1 System.out.println(-2 >>> 1); // 2147483647 /* * -2: * 原碼:1000 0000 0000 0000 0000 0000 0000 0010 * 反碼:1111 1111 1111 1111 1111 1111 1111 1101 * 補碼:1111 1111 1111 1111 1111 1111 1111 1110 * * 右移1位操作(操作補碼) * * 補碼:1111 1111 1111 1111 1111 1111 1111 1111 * 反碼:1111 1111 1111 1111 1111 1111 1111 1110 * 原碼:1000 0000 0000 0000 0000 0000 0000 0001 * * 無符號右移1位操作(操作補碼) * * 補碼:0111 1111 1111 1111 1111 1111 1111 1111 * 反碼:0111 1111 1111 1111 1111 1111 1111 1111 * 原碼:0111 1111 1111 1111 1111 1111 1111 1111 */
總結
本篇文章就到這裡瞭,希望能給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!
推薦閱讀:
- JavaScript中極易出錯的操作符運算總結
- Java Float 保留小數位精度的實現
- ECMAScript 數據類型之Number類型
- java中a=a+1和a+=1的區別介紹
- 一篇文章帶你搞懂JavaScript的變量與數據類型