帶你盤點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的更多內容!

推薦閱讀: