C/C++中運(yùn)算符的優(yōu)先級(jí)、運(yùn)算符的結(jié)合性詳解
一.運(yùn)算符的優(yōu)先級(jí)
在C++ Primer一書(shū)中,對(duì)于運(yùn)算符的優(yōu)先級(jí)是這樣描述的:
Precedence specifies how the operands are grouped. It says nothing about the order in which the operands are evaluated.
意識(shí)是說(shuō)優(yōu)先級(jí)規(guī)定操作數(shù)的結(jié)合方式,但并未說(shuō)明操作數(shù)的計(jì)算順序。舉個(gè)例子:
6+3*4+2
如果直接按照從左到右的計(jì)算次序得到的結(jié)果是:38,但是在C/C++中它的值為20。
因?yàn)槌朔ㄟ\(yùn)算符的優(yōu)先級(jí)高于加法的優(yōu)先級(jí),因此3是和4分組到一起的,并不是6與3進(jìn)行分組。這就是運(yùn)算符優(yōu)先級(jí)的含義。
二.運(yùn)算符的結(jié)合性
Associativity specifies how to group operators at the same precedence level.
結(jié)合性規(guī)定了具有相同優(yōu)先級(jí)的運(yùn)算符如何進(jìn)行分組。
舉個(gè)例子:
a=b=c=d;
由于該表達(dá)式中有多個(gè)賦值運(yùn)算符,到底是如何進(jìn)行分組的,此時(shí)就要看賦值運(yùn)算符的結(jié)合性了。因?yàn)橘x值運(yùn)算符是右結(jié)合性,因此該表達(dá)式等同于(a=(b=(c=d))),而不是(a=(b=c)=d)這樣進(jìn)行分組的。
同理如m=a+b+c;
等同于m=(a+b)+c;而不是m=a+(b+c);
三.操作數(shù)的求值順序
在C/C++中規(guī)定了所有運(yùn)算符的優(yōu)先級(jí)以及結(jié)合性,但是并不是所有的運(yùn)算符都被規(guī)定了操作數(shù)的計(jì)算次序。在C/C++中只有4個(gè)運(yùn)算符被規(guī)定了操作數(shù)的計(jì)算次序,它們是&&,||,逗號(hào)運(yùn)算符(,),條件運(yùn)算符(?:)。
如m=f1()+f2();
在這里是先調(diào)用f1(),還是先調(diào)用f2()?不清楚,不同的編譯器有不同的調(diào)用順序,甚至相同的編譯器不同的版本會(huì)有不同的調(diào)用順序。只要最終結(jié)果與調(diào)用次序無(wú)關(guān),這個(gè)語(yǔ)句就是正確的。這里要分清楚操作數(shù)的求值順序和運(yùn)算符的結(jié)合性這兩個(gè)概念,可能有時(shí)候會(huì)這樣去理解,因?yàn)榧臃ú僮鞣慕Y(jié)合性是左結(jié)合性,因此先調(diào)用f1(),再調(diào)用f2(),這種理解是不正確的。結(jié)合性是確定操作符的對(duì)象,并不是操作數(shù)的求值順序。
同理2+3*4+5;
它的結(jié)合性是(2+(3*4))+5,但是不代表3*4是最先計(jì)算的,它的計(jì)算次序是未知的,未定義的。
比如3*4->2+3*4->2+3*4+5
以及2->3*4->2+3*4->2+3*4+5和5->3*4->2+3*4->2+3*4+5這些次序都是有可能的。雖然它們的計(jì)算次序不同,但是對(duì)最終結(jié)果是沒(méi)有影響的。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
C++ OpenCV實(shí)戰(zhàn)之網(wǎng)孔檢測(cè)的實(shí)現(xiàn)
這篇文章主要介紹了如何利用C++和OpenCV實(shí)現(xiàn)網(wǎng)孔檢測(cè),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定幫助,感興趣的小伙伴可以了解一下2022-05-05
C++遍歷磁盤(pán)驅(qū)動(dòng)器的示例代碼
這篇文章主要介紹了C++遍歷磁盤(pán)驅(qū)動(dòng)器的示例代碼,幫助大家更好的理解和使用c++,感興趣的朋友可以了解下2021-01-01
如何用C語(yǔ)言畫(huà)一個(gè)“圣誕樹(shù)”
這篇文章主要介紹了如何用C語(yǔ)言畫(huà)一個(gè)“圣誕樹(shù)”,感興趣的小伙伴們可以參考一下2015-12-12
C++標(biāo)準(zhǔn)庫(kù)封裝的vector數(shù)組
這篇文章主要介紹了C++標(biāo)準(zhǔn)庫(kù)封裝的vector數(shù)組,vector創(chuàng)建的對(duì)象包含眾多封裝好的函數(shù),想了解其相關(guān)資料的小伙伴可以參考下面文章內(nèi)容,希望對(duì)你的學(xué)習(xí)有所幫助2022-03-03
c++網(wǎng)絡(luò)編程下Linux的epoll技術(shù)和Windows下的IOCP模型
c++ 網(wǎng)絡(luò)編程LINUX-epoll/windows-IOCP下socket opoll函數(shù)用法 優(yōu)于select方法的epoll 以及windows下IOCP 解決多進(jìn)程服務(wù)端創(chuàng)建進(jìn)程資源浪費(fèi)問(wèn)題,感興趣的小伙伴一起來(lái)學(xué)習(xí)吧2021-08-08
C++解密Chrome80版本數(shù)據(jù)庫(kù)的方法示例代碼
這篇文章主要介紹了C++解密Chrome80版本數(shù)據(jù)庫(kù)的方法示例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
淺談#ifndef,#define,#endif的作用和用法
下面小編就為大家?guī)?lái)一篇淺談#ifndef,#define,#endif的作用和用法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12
C++使用ZLIB庫(kù)實(shí)現(xiàn)目錄壓縮與解壓功能
在軟件開(kāi)發(fā)和數(shù)據(jù)處理中,對(duì)數(shù)據(jù)進(jìn)行高效的壓縮和解壓縮是一項(xiàng)重要的任務(wù),這不僅有助于減小數(shù)據(jù)在網(wǎng)絡(luò)傳輸和存儲(chǔ)中的占用空間,還能提高系統(tǒng)的性能和響應(yīng)速度,本文將介紹如何使用 zlib 庫(kù)進(jìn)行數(shù)據(jù)的壓縮和解壓縮,以及如何保存和讀取壓縮后的文件2025-02-02

