Java基礎(chǔ)之詳細(xì)總結(jié)五種常用運(yùn)算符
一、算術(shù)運(yùn)算符
算術(shù)運(yùn)算符的符號(hào)通常為:加(+)、減(-)、乘(*)、除(/)、取余(%)、自增(++)、自減(--)。
使用int類(lèi)型的變量和int類(lèi)型的變量做除法,得到的結(jié)果還是int類(lèi)型;
使用double類(lèi)型的常量和 int類(lèi)型的常量做除法,會(huì)得到double類(lèi)型的結(jié)果;在使用強(qiáng)制類(lèi)型double轉(zhuǎn)換可以得到double類(lèi)型
System.out.println(7 / 2);//3.0 System.out.println((double)(7 / 2)); // 3.0 System.out.println((double)7 / 2); // 3.5
既然存在除法,那么對(duì)于除0這個(gè)特殊的數(shù),Java的程序是怎么處理的呢,是否都是異常的報(bào)錯(cuò)呢?我們可以執(zhí)行試一下
// 產(chǎn)生異常:java.lang.ArithmeticException: / by zero int i = 123 / 0; System.out.println(i); // 產(chǎn)生異常: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(正無(wú)窮大) double y = -123.45 / 0; System.out.println(y); // -Infinity(負(fù)無(wú)窮大) double m = 0.0 / 0; System.out.println(m); // NaN(Not a number 不是一個(gè)數(shù)) double n = -0.0 / 0; System.out.println(n); // NaN(Not a number 不是一個(gè)數(shù)) float x = 123.45F / 0; System.out.println(x); // Infinity(正無(wú)窮大) float y = -123.45F / 0; System.out.println(y); // -Infinity(負(fù)無(wú)窮大) float m = 0.0F / 0; System.out.println(m); // NaN(Not a number 不是一個(gè)數(shù)) float n = -0.0F / 0; System.out.println(n); // NaN(Not a number 不是一個(gè)數(shù)) //產(chǎn)生異常:java.lang.ArithmeticException: / by zero int x = 11 % 0; System.out.println(x); double y = 11.0 % 0; System.out.println(y); // NaN
自增運(yùn)算符
單獨(dú)使用自增運(yùn)算符:不論++放在需要自增的變量的前面還是后面,都會(huì)在操作后讓變量的值自增1
非單獨(dú)使用自增運(yùn)算符:int j = i++; // i: 3 j: 2(一上來(lái)先把i的值賦值給j,然后i自己做自增(先賦值再自增));int j = ++i; // i: 3 j: 3(上來(lái)先i自己做自增,然后把i的值(自增后的值)賦值給j(先自增再賦值));
這里附加一個(gè)練習(xí)題:
int i = 2; int j = 3; j = i++ + ++i+i*6;
最后j是多少?(結(jié)果是:30)
二、賦值運(yùn)算符
賦值運(yùn)算符:=、+=、-=、*=、/=、%=
這個(gè)沒(méi)什么說(shuō)的只是進(jìn)行賦值的操作,只是要注意對(duì)于非默認(rèn)數(shù)據(jù)類(lèi)型的數(shù)據(jù),使用帶有算術(shù)運(yùn)算符的賦值運(yùn)算符時(shí),會(huì)自動(dòng)進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換,例如:
byte j = 5;j += 6; // 下句等價(jià)于上句 j = (byte) (j + 6);
三、比較運(yùn)算符
比較運(yùn)算符:==、!=、>、<、>=、<=;Java中使用 == 表示相等(內(nèi)容相等)
四、邏輯運(yùn)算符
邏輯運(yùn)算符:&、|、!、^、&&、||
&:邏輯與,有一個(gè)是false得到的結(jié)果就是false
|:邏輯或,有一個(gè)是true得到的結(jié)果就是true
!:邏輯非,顛倒黑白
^:邏輯異或,類(lèi)似吸鐵石(真假為真,真真為假,假假為假)
&&:邏輯與,如果參與運(yùn)算的第一個(gè)變量或表達(dá)式為false,得到的結(jié)果就是false,其他的變量或表達(dá)式就不去執(zhí)行;如果多個(gè)邏輯與參與運(yùn)算,以此類(lèi)推; ||:邏輯或,如果參與運(yùn)算的第一個(gè)變量或表達(dá)式為true,得到的結(jié)果就是true,其他的變量或表達(dá)式就不去執(zhí)行;如果多個(gè)邏輯與參與運(yùn)算,以此類(lèi)推;
&和&&區(qū)別:&&具有短路的操作,比如第一個(gè)表達(dá)式是false時(shí),是不會(huì)執(zhí)行第二個(gè)表達(dá)式(if(s!=null&&s.equal(""))),如果s是null的話(huà)使用&就會(huì)報(bào)錯(cuò);&可以可以用在位運(yùn)算符中。
練習(xí)題:
int i = 2; int j = 3; System.out.println((++i == 2) && (j++ == 3));
問(wèn):最終i 和 j 的值是多少?(i為3,j為3)
int i = 2; int j = 3; System.out.println((++i == 2) & (j++ == 3));
問(wèn):最終i 和 j 的值是多少?(i為3,j為4)
五、位運(yùn)算符
位運(yùn)算符:&、|、~、^、>>、>>>、<<
規(guī)則:(在二進(jìn)制中)操作的是補(bǔ)碼
&:位與,進(jìn)行操作的兩個(gè)數(shù)的同一位上,有一個(gè)是0,該位運(yùn)算的結(jié)果就是0
|:位或,進(jìn)行操作的兩個(gè)數(shù)的同一位上,有一個(gè)是1,該位運(yùn)算的結(jié)果就是1
~:位非,進(jìn)行操作的數(shù)按位取反
^:位異或,進(jìn)行操作的兩個(gè)數(shù)的同一位上,兩個(gè)相同為0,兩個(gè)不同為1(規(guī)律:一個(gè)數(shù)連續(xù)兩次和另一個(gè)數(shù)做位異或運(yùn)算,得到其本身的值)
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 * 補(bǔ)碼:0000 0000 0000 0000 0000 0000 0000 0010 * * ~2 * 補(bǔ)碼:1111 1111 1111 1111 1111 1111 1111 1101 * 反碼:1111 1111 1111 1111 1111 1111 1111 1100 * 原碼:1000 0000 0000 0000 0000 0000 0000 0011 */
<<:左移,左邊的高位刪除,右邊的低位補(bǔ)0
>>:右移,因?yàn)樽髠?cè)的最高位是符號(hào)位,所以要區(qū)分是0還是1;左側(cè)的最高位是0,左側(cè)補(bǔ)0;左側(cè)的最高位是1,左側(cè)補(bǔ)1 >>>:無(wú)符號(hào)右移,不論左側(cè)的最高位是0還是1,左側(cè)補(bǔ)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 * 補(bǔ)碼:1111 1111 1111 1111 1111 1111 1111 1110 * * 右移1位操作(操作補(bǔ)碼) * * 補(bǔ)碼:1111 1111 1111 1111 1111 1111 1111 1111 * 反碼:1111 1111 1111 1111 1111 1111 1111 1110 * 原碼:1000 0000 0000 0000 0000 0000 0000 0001 * * 無(wú)符號(hào)右移1位操作(操作補(bǔ)碼) * * 補(bǔ)碼:0111 1111 1111 1111 1111 1111 1111 1111 * 反碼:0111 1111 1111 1111 1111 1111 1111 1111 * 原碼:0111 1111 1111 1111 1111 1111 1111 1111 */
到此這篇關(guān)于Java基礎(chǔ)之詳細(xì)總結(jié)五種運(yùn)算符的文章就介紹到這了,更多相關(guān)Java五種運(yùn)算符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 線(xiàn)程方法join簡(jiǎn)單用法實(shí)例總結(jié)
這篇文章主要介紹了java 線(xiàn)程方法join簡(jiǎn)單用法,結(jié)合實(shí)例形式總結(jié)分析了Java線(xiàn)程join方法的功能、原理及使用技巧,需要的朋友可以參考下2019-11-11關(guān)于Java的動(dòng)態(tài)代理機(jī)制
這篇文章主要介紹了關(guān)于Java的動(dòng)態(tài)代理機(jī)制,動(dòng)態(tài)代理就是,在程序運(yùn)行期,創(chuàng)建目標(biāo)對(duì)象的代理對(duì)象,并對(duì)目標(biāo)對(duì)象中的方法進(jìn)行功能性增強(qiáng)的一種技術(shù),需要的朋友可以參考下2023-05-05Java實(shí)現(xiàn)后端跨域的常見(jiàn)解決方案
跨源資源共享(CORS——Cross-Origin Resource Sharing,跨源資源共享,或通俗地譯為跨域資源共享)是一種基于 HTTP 頭的機(jī)制,跨域的解決方案有很多種,前后端都有,本文給大家主要介紹Java實(shí)現(xiàn)后端跨域的常見(jiàn)解決方案,需要的朋友可以參考下2024-04-04java實(shí)現(xiàn)Dijkstra最短路徑算法
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)Dijkstra最短路徑算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01使用java實(shí)現(xiàn)http多線(xiàn)程斷點(diǎn)下載文件(一)
Java 多線(xiàn)程斷點(diǎn)下載文件基本原理:利用URLConnection獲取要下載文件的長(zhǎng)度、頭部等相關(guān)信息,并設(shè)置響應(yīng)的頭部信息,本文將詳細(xì)介紹,需要了解更多的朋友可以參考下2012-12-12Java中的遞增i++與++i的實(shí)現(xiàn)原理詳解
這篇文章主要介紹了Java中的i++與++i的實(shí)現(xiàn)原理詳解,在Java中,i++是一種常見(jiàn)的遞增操作符,用于將變量i的值增加1,它是一種簡(jiǎn)潔且方便的方式來(lái)實(shí)現(xiàn)循環(huán)和計(jì)數(shù)功能,i++可以用于各種情況,本文來(lái)看一下其實(shí)現(xiàn)原理,需要的朋友可以參考下2023-10-10SpringCloud?Eureka服務(wù)注冊(cè)中心應(yīng)用入門(mén)詳解
這篇文章主要介紹了Spring?Cloud?Eureka服務(wù)注冊(cè)中心入門(mén)流程分析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07