溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java操作符與其優(yōu)先級的示例分析

發(fā)布時間:2021-08-26 11:10:17 來源:億速云 閱讀:127 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關(guān)Java操作符與其優(yōu)先級的示例分析的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

幾乎所有運(yùn)算符都只能操作“主類型”(Primitives)。例外是“=”、“= =”和“! =”,它們能操作所有對象。除此以外,String類支持“+”和“+=”。

基本類型存儲了實(shí)際的數(shù)值。而并非指向一個對象的引用。所以在為其賦值的時候,是直接把一個地方的內(nèi)容復(fù)制到了另一個地方。例如,對基本數(shù)據(jù)類型使用a=b,那么b的內(nèi)容就復(fù)制給了a。若接著修改了a,而b根本不會受這種修改的影響。(在上一篇java編程思想(2)中,我們就知道基本類型是存儲在堆棧中的。假設(shè)a=4,那么堆棧中如果沒有4,則會開辟一個空間,使值為4。a=b之后,b也指向了堆棧中的這個4。此時a再等于5。那么會重新在堆棧中尋找5,若沒有則新開辟使之為5,然后a指向5。故不會影響b)

但是在為對象“賦值”的時候,情況會發(fā)生變化。首先我們知道,對對象的操作,我們真正操作的是對對象的引用。所以倘若"將一個對象賦值給另一個對象",實(shí)際上是將“引用”從一個地方復(fù)制到另一個地方。這意味著如果對對象使用c=d之后,那么c和d都將指向原來只有d指向的那個對象(兩個遙控器(引用)都能操作按個電視機(jī)(對象)了)。

優(yōu)先級:


 操作

優(yōu)先級

結(jié)合性


1

后綴運(yùn)算符

[ ] . ( ) (函數(shù)呼叫)

從左到右

2

單目運(yùn)算符

! ~ ++ -- +(單操作數(shù)) –(單操作數(shù))

從右到左

3

創(chuàng)建

new

從左到右

4

乘除

* / %

從左到右

5

加減

+ -

從左到右

6

移位

<< >> >>>

從左到右

7

關(guān)系

< <= > >= instanceof

從左到右

8

相等

== !=

從左到右

9

按位與

&

從左到右

10

按位異或

^

從左到右

11

按位或

|

從左到右

12

邏輯與

&&

從左到右

13

邏輯或

||

從左到右

14

條件

? :

從右到左

15

賦值

= += -= *= /= %= ^= <<= >>= >>>=

從右到左

(1)賦值

主類型使用“A=B”,那么B處的內(nèi)容就復(fù)制到A。若修改A,那么B根本不會受修改的影響。

對象“賦值”的時候情況發(fā)生了變化。對一個對象進(jìn)行操作時,我們真正操作的是它的句柄。所以倘若“從一個對象到另一個對象”賦值,實(shí)際就是將句柄從一個地方復(fù)制到另一個地方。這意味著假若為對象使用“C=D”,那么C和D最終都會指向最初只有D才指向的那個對象。

short s1 = 1; s1 = s1 + 1; (s1+1運(yùn)算結(jié)果是int型,需要強(qiáng)制轉(zhuǎn)換類型)

short s1 = 1; s1 += 1;(可以正確編譯) +=運(yùn)算符無類型轉(zhuǎn)換問題

(2)算術(shù)運(yùn)算符

Java的算術(shù)運(yùn)算符:加號(+)、減號(-)、除號(/)、乘號(*)以及模數(shù)(%,從整數(shù)除法中獲得余數(shù))。整數(shù)除法會直接砍掉小數(shù),而不是進(jìn)位。

(3)自動遞增、遞減

對于前遞增和前遞減(如++A或--A),會先執(zhí)行運(yùn)算,再生成值。

對于后遞增和后遞減(如A++或A--),會先生成值,再執(zhí)行運(yùn)算。

(4)關(guān)系運(yùn)算符

關(guān)系運(yùn)算符包括<、>、<=、>=、= =、!=

等于和不等于適用于所有內(nèi)建的數(shù)據(jù)類型,但其他比較不適用于boolean類型。

想對比兩個對象的實(shí)際內(nèi)容是否相同,必須使用所有對象都適用的特殊方法equals()。

equals()方法不適用于“主類型”,那些類型直接使用= =和!=即可。

equals()的默認(rèn)是比較句柄。所以除非在自己的新類中改變了equals(),否則不可能表現(xiàn)出我們希望的行為

大多數(shù)Java類庫都實(shí)現(xiàn)了equals(),所以它實(shí)際比較的是對象的內(nèi)容,而非它們的句柄

= =和! =比較的是對象句柄,而不是對象的實(shí)際內(nèi)容

(5)邏輯運(yùn)算符

邏輯運(yùn)算符&&、||、!能生成一個布爾值

&和&&都可作為邏輯運(yùn)算符“與”使用,但是&&是“短路與”,運(yùn)算時先判斷符號前面的表達(dá)式的值,如果能夠確定整個表達(dá)式的值,則不進(jìn)行符號后面的表達(dá)式的運(yùn)算。

另外,&可作為位運(yùn)算符使用

(6)按位運(yùn)算符

按位AND運(yùn)算符(&)

按位OR運(yùn)算符(|)

按位XOR(^,異或)

按位NOT(~,也叫作“非”運(yùn)算符)屬于一元運(yùn)算符,生成與輸入位的相反的值

(7)移位運(yùn)算符

左移位運(yùn)算符(<<)能將運(yùn)算對象向左移動運(yùn)算符右側(cè)指定的位數(shù)(在低位補(bǔ)0)。

有符號右移位運(yùn)算符(>>)將運(yùn)算對象向右移動運(yùn)算符右側(cè)指定的位數(shù)。有符號右移位運(yùn)算符使用了符號擴(kuò)展:若值為正,則在高位插入0;若值為負(fù),則在高位插入1

無符號右移位運(yùn)算符(>>>),它使用了“零擴(kuò)展”:無論正負(fù),都在高位插入0

(8)三元IF-ELSE運(yùn)算符

布爾表達(dá)式 ? 值0:值1 “布爾表達(dá)式”的結(jié)果為true,就計(jì)算“值0”,否則計(jì)算“值1”

(9)字符串運(yùn)算符+

int x = 0, y = 1, z = 2;
System.out.println(“out:” + x + y + z);

在這里,Java編譯程序會將x,y和z轉(zhuǎn)換成它們的字串形式,而不是先把它們加到一起

運(yùn)用“String +”時,若表達(dá)式以一個String起頭,那么后續(xù)所有運(yùn)算對象都會轉(zhuǎn)換到字串。

想通過“加號”連接字串(使用Java的早期版本),請務(wù)必保證第一個元素是字串

(10)造型(Cast)運(yùn)算符

對于“縮小轉(zhuǎn)換”(Narrowing Conversion)的操作(能容納更多信息的數(shù)據(jù)類型,將其轉(zhuǎn)換成容量較小的類型,例如int轉(zhuǎn)short),此時就可能面臨信息丟失的危險。此時,編譯器會強(qiáng)迫我們進(jìn)行明確造型

對于“放大轉(zhuǎn)換”(Widening conversion),則不必進(jìn)行明確造型,因?yàn)樾骂愋涂隙苋菁{原來類型的信息,不會造成任何信息的丟失

布爾值(bollean)根本不允許進(jìn)行任何造型處理,其它任何主類型可互相造型

將float或double值造型成整數(shù)值后,總是將小數(shù)部分“砍掉”,不作任何進(jìn)位處理

Math.round(11.5)等於多少? Math.round(-11.5)等於多少?

Math.round(11.5)==12 Math.round(-11.5)==-11

round方法返回與參數(shù)最接近的長整數(shù),參數(shù)加1/2后求其floor.

感謝各位的閱讀!關(guān)于“Java操作符與其優(yōu)先級的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI