C++中的運算符和表達式

在編程語言中“表達式”可以近似于“公式”,也就是按照自己的預(yù)期進行某種計算,表達式由運算符合操作數(shù)等構(gòu)成。C++中包含單目(一元)運算符、雙目(二元)運算符和三目(三元)運算符,相應(yīng)的構(gòu)成了多種表達式。運算符具有優(yōu)先級和結(jié)合性,優(yōu)先級指先后計算次序,結(jié)合性指同級運算符時按照自左向右還是自右向左進行計算。
(1)算術(shù)表達式
算術(shù)表達式由算術(shù)運算符、操作數(shù)和括號構(gòu)成,基本運算符包含:加+、減-、乘*、除\、取余%,只有“加、減”在做“正、負(fù)”符號時是一元運算符,其余情況都是二元運算符。C++擁有自加++和自減--兩個一元運算符(python應(yīng)該沒有自加和自減,因為python中數(shù)值是不可變類型,改變值會申請新的內(nèi)存),當(dāng)表達式中存在自加或者自減運算時,一定要注意自加和自減是在操作數(shù)之前還是操作數(shù)之后,在操作數(shù)之前表示先自加再計算整個表達式,在操作數(shù)之后表示先計算整個表達式再自加,
比如下面的代碼:
int age_1 = 22; int age_2 = 22; int new_age_1; int new_age_2; new_age_1 = age_1++; new_age_2 = ++age_2;
第5行計算new_age_1時,先計算完整個表達式,再進行age_1的自加,所以new_age_1
等于22;第6行計算new_age_2時,先對age_2進行自加,再進行表達式計算,所以new_age_2等于23。自己在寫代碼時最好不要給自己挖坑,少使用過于復(fù)雜的表達式。
(2)賦值運算符
賦值運算符“=”是雙目運算符,結(jié)合性是自右向左,允許連續(xù)賦值:
int x, y, z; x = y = z = 1;
此外,C++還有+=、*=、/=等等運算符,結(jié)合性都是自右向左。
(3)逗號運算符
逗號運算符可以分隔兩個表達式,先計算左邊表達式再計算右邊的表達式,但是由于逗號運算符的優(yōu)先級低于賦值運算符,所以采用逗號運算符進行賦值時必須把逗號表達式括起來,
下面兩行代碼得到的x值是不同的:
x = (2, 3); x = 2, 3;
第一行x等于3,第二行x等于2,因為逗號運算符的優(yōu)先級低于賦值運算符,自己在使用中必須小心。
(4)關(guān)系運算符
關(guān)系運算符是邏輯表達式的基礎(chǔ),C++包含的關(guān)系運算符分兩個優(yōu)先級,較高的優(yōu)先級為:大于、小于、大于等于和小于等于四種,分別用<、<=、>、>=來表示;較低的優(yōu)先級為:等于、不等于,分別用==、!=表示。邏輯表達式返回的值為布爾類型,判斷為真返回True(0),判斷為假返回False(1),
如下:
int x = 2; int y = 3; bool result; result = (x >= y);
C++還擁有三個邏輯運算符:與、或、非,分別用||、&&、!三個符號表示。
(5)三元表達式
據(jù)自己目前所知,C++唯一的三元運算符是條件運算符,其語法如下:
條件判斷? 表達式1:表達式2
當(dāng)判斷條件成立時,執(zhí)行表達式1;當(dāng)判斷條件不成立時,執(zhí)行表達式2,
代碼如下:
int x = 2; int y = 3; int result; result = (x>y? 10: 1000);
由于x>y不成立,所以執(zhí)行表達式2,也就是result被賦值為1000。
(6)sizeof函數(shù)
書中稱sizeof為單獨的運算符,為了便于理解這里把其視為函數(shù)。sizeof可以求取對象的占用的字節(jié)數(shù),下面的例子計算了int類型占用的字節(jié)數(shù):
int result=1000; cout << sizeof(result) <<endl;
輸出為4,表示int占用4個字節(jié),這和理論上是一致的。
(7)數(shù)據(jù)類型轉(zhuǎn)換
數(shù)據(jù)類型轉(zhuǎn)換是編程語言面臨的共同問題,對于表達式中存在多種數(shù)據(jù)類型的情況必須采用有效的處理策略。C++數(shù)據(jù)類型轉(zhuǎn)換包含顯式轉(zhuǎn)換和隱式轉(zhuǎn)換兩種,下面分別進行介紹。
(7.1)顯式轉(zhuǎn)換
如果自己清晰的知道表達式中各個對象是什么類型,并且清晰的知道想要將對象變?yōu)楹畏N新的類型,那么可以使用:類型說明符(表達式)進行顯式的類型轉(zhuǎn)換,
比如將float類型的x轉(zhuǎn)換為int類型的y:
float x = 6.66; int y = int(x); ??
上述代碼運行后y的值為6,僅僅取x的整數(shù)部分。顯式類型轉(zhuǎn)換時,如果自己選擇的類型說明符的精度較低,比如上述代碼中x為高精度,但是類型說明符int為低精度,則數(shù)據(jù)類型轉(zhuǎn)換過程中造成了精度丟失。
(7.2)隱式轉(zhuǎn)換
如果表達式中有高精度和低精度兩種數(shù)據(jù)參與計算,會自動將低精度數(shù)據(jù)轉(zhuǎn)換為高精度數(shù)據(jù)進行計算,這種隱式轉(zhuǎn)換是沒有精度丟失的安全轉(zhuǎn)換:
float x = 6.66; int y = 2; cout << x+y <<endl;
上述代碼中浮點x和整型y進行加法時,按照浮點類型進行計算輸出6.66。
另外,邏輯表達式中0和非0數(shù)據(jù)分別會被轉(zhuǎn)換為true和false,賦值表達式自動將等號右邊的類型轉(zhuǎn)換為等號左邊的類型。
(8)總結(jié)
C++的包含的運算符和表達式總體來說和python差不多,類型轉(zhuǎn)換的規(guī)則也很符合直觀的理解。位運算符部分暫時沒進行記錄是因為其并不常用,等用到的時候再學(xué)習(xí)。
參考:
- 鄭莉《C++語言程序設(shè)計》
到此這篇關(guān)于C++中的運算符和表達式的文章就介紹到這了,更多相關(guān)C++運算符和表達式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實現(xiàn)學(xué)籍信息管理系統(tǒng)
這篇文章主要為大家詳細介紹了C語言實現(xiàn)學(xué)籍信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07
C++實現(xiàn)簡單的學(xué)生成績管理系統(tǒng)
這篇文章主要為大家詳細介紹了C++實現(xiàn)簡單的學(xué)生成績管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
C++使用WideCharToMultiByte函數(shù)生成UTF-8編碼文件的方法
用來映射Unicode字符串的WideCharToMultiByte函數(shù)經(jīng)常被用來進行UTF-8編碼的轉(zhuǎn)換,以下我們將看到C++使用WideCharToMultiByte函數(shù)生成UTF-8編碼文件的方法,首先先來對WideCharToMultiByte作一個詳細的了解:2016-06-06

