亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java基礎(chǔ)之詳細(xì)總結(jié)五種常用運(yùn)算符

 更新時(shí)間:2021年05月21日 10:17:37   作者:香菜聊游戲  
在通常代碼邏輯處理中,我們常常都會(huì)使用到運(yùn)算符,今天我們就詳細(xì)了解一下運(yùn)算符的使用以及分類(lèi).運(yùn)算符是對(duì)常量或者變量進(jìn)行操作的符號(hào),它分為算術(shù)運(yùn)算符,賦值運(yùn)算符,比較運(yùn)算符,邏輯運(yùn)算符以及位運(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解析xml的四種方法匯總

    Java解析xml的四種方法匯總

    XML在不同的語(yǔ)言里解析方式都是一樣的,只不過(guò)實(shí)現(xiàn)的語(yǔ)法不同而已。java中基本的解析方式有四種,DOM解析、sax解析、JDOM解析和DOM4J解析,下面我們就來(lái)詳細(xì)探討下這四種方式
    2016-05-05
  • java 線(xiàn)程方法join簡(jiǎn)單用法實(shí)例總結(jié)

    java 線(xiàn)程方法join簡(jiǎn)單用法實(shí)例總結(jié)

    這篇文章主要介紹了java 線(xiàn)程方法join簡(jiǎn)單用法,結(jié)合實(shí)例形式總結(jié)分析了Java線(xiàn)程join方法的功能、原理及使用技巧,需要的朋友可以參考下
    2019-11-11
  • Java 10 局部變量類(lèi)型推斷淺析

    Java 10 局部變量類(lèi)型推斷淺析

    這篇文章主要介紹了Java 10 局部變量類(lèi)型推斷淺析,Java 10 引進(jìn)一種新的閃閃發(fā)光的特性叫做局部變量類(lèi)型推斷。文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06
  • 關(guān)于Java的動(dòng)態(tài)代理機(jī)制

    關(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-05
  • Java實(shí)現(xiàn)后端跨域的常見(jiàn)解決方案

    Java實(shí)現(xiàn)后端跨域的常見(jiàn)解決方案

    跨源資源共享(CORS——Cross-Origin Resource Sharing,跨源資源共享,或通俗地譯為跨域資源共享)是一種基于 HTTP 頭的機(jī)制,跨域的解決方案有很多種,前后端都有,本文給大家主要介紹Java實(shí)現(xiàn)后端跨域的常見(jiàn)解決方案,需要的朋友可以參考下
    2024-04-04
  • Java?Spring讀取和存儲(chǔ)詳細(xì)操作

    Java?Spring讀取和存儲(chǔ)詳細(xì)操作

    這篇文章主要介紹了Spring讀取和存儲(chǔ)詳細(xì)操作,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • java實(shí)現(xiàn)Dijkstra最短路徑算法

    java實(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實(shí)現(xiàn)http多線(xiàn)程斷點(diǎn)下載文件(一)

    Java 多線(xiàn)程斷點(diǎn)下載文件基本原理:利用URLConnection獲取要下載文件的長(zhǎng)度、頭部等相關(guān)信息,并設(shè)置響應(yīng)的頭部信息,本文將詳細(xì)介紹,需要了解更多的朋友可以參考下
    2012-12-12
  • Java中的遞增i++與++i的實(shí)現(xiàn)原理詳解

    Java中的遞增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-10
  • SpringCloud?Eureka服務(wù)注冊(cè)中心應(yīng)用入門(mén)詳解

    SpringCloud?Eureka服務(wù)注冊(cè)中心應(yīng)用入門(mén)詳解

    這篇文章主要介紹了Spring?Cloud?Eureka服務(wù)注冊(cè)中心入門(mén)流程分析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07

最新評(píng)論