摘要:語言基礎(chǔ)之操作符詳解操作符的分類算術(shù)操作符移位操作符位操作符邏輯操作符逗號(hào)表達(dá)式表達(dá)式求值隱式類型轉(zhuǎn)換算術(shù)轉(zhuǎn)換操作符的屬性今天就帶各位大佬來了解一波語言的操作符。
常見的操作符分別如下:
算術(shù)操作符是我們最常用的操作符:+ - * / %
注:
移位操作符分為左移操作符和右移操作符,移位操作符的操作對(duì)象只能是整數(shù),且所謂的移位是對(duì)于整數(shù)的二進(jìn)制位進(jìn)行移位:
左移操作符:<<
右移操作符:>>
注:對(duì)于移位運(yùn)算符,不要移動(dòng)負(fù)數(shù)位,這個(gè)是標(biāo)準(zhǔn)未定義的。
位操作符有:
& —— 按位與
| —— 按位或
^ —— 按位異或
位操作符的操作數(shù)必須是整數(shù),且是對(duì)其二進(jìn)制的補(bǔ)碼進(jìn)行操作。
異或的基本性質(zhì):
例:不創(chuàng)建臨時(shí)變量使兩個(gè)數(shù)進(jìn)行交換
#include int main(){ int a = 10; int b = 20; a = a^b; b = a^b; a = a^b; printf("a = %d b = %d/n", a, b); return 0;}
邏輯操作符分為:
&& —— 邏輯與
|| —— 邏輯或
邏輯與:
必須使 && 左右兩個(gè)表達(dá)式都為真
邏輯或:
|| 兩邊有一個(gè)式子為真即為真
逗號(hào)表達(dá)式是用逗號(hào)隔開的多個(gè)表達(dá)式:
exp1, exp2, exp3, …expN
逗號(hào)表達(dá)式,從左向右依次執(zhí)行,整個(gè)表達(dá)式的結(jié)果是最后一個(gè)表達(dá)式的結(jié)果。
表達(dá)式求值的順序一部分是由操作符的優(yōu)先級(jí)和結(jié)合性決定,但是,有些表達(dá)式的操作數(shù)在求值的過程中可能需要轉(zhuǎn)換為其他類型。
C語言的整型算術(shù)運(yùn)算總是至少以缺省整型類型的精度來進(jìn)行的,為了獲得這個(gè)精度,表達(dá)式中的字符和短整型操作數(shù)在使用之前被轉(zhuǎn)換為普通整型,這種轉(zhuǎn)換稱為整型提升。
實(shí)例:
char a,b,c;...a = b + c;
b和c的值被提升為普通整型,然后再執(zhí)行加法運(yùn)算,加法運(yùn)算完成之后,結(jié)果將被截?cái)?,然后再存?chǔ)于a中。
整形提升是按照變量的數(shù)據(jù)類型的符號(hào)位來提升的,若操作對(duì)象為正數(shù)則補(bǔ)0,操作對(duì)象為負(fù)數(shù)則補(bǔ)1。
負(fù)數(shù)的整形提升
char c1 = -1;
變量c1的二進(jìn)制位(補(bǔ)碼)中只有8個(gè)比特位:
1111111
因?yàn)?char 為有符號(hào)的 char
所以整形提升的時(shí)候,高位補(bǔ)充符號(hào)位,即為1
提升之后的結(jié)果是:
11111111111111111111111111111111
正數(shù)的整形提升
char c2 = 1;
變量c2的二進(jìn)制位(補(bǔ)碼)中只有8個(gè)比特位:
00000001
因?yàn)?char 為有符號(hào)的 char
所以整形提升的時(shí)候,高位補(bǔ)充符號(hào)位,即為0
提升之后的結(jié)果是:
00000000000000000000000000000001
無符號(hào)整形提升,高位補(bǔ)0
int main(){ char a = 5; //存在char、short計(jì)算時(shí)發(fā)生整形提升 //00000000000000000000000000000101 //截?cái)嗪?/span> //00000101 - a //整型提升后(整形提升是按照變量的數(shù)據(jù)類型的符號(hào)位來提升的) //00000000000000000000000000000101 char b = 126; //00000000000000000000000001111110 //01111110 - b //整型提升后 //00000000000000000000000001111110 char c = a + b; //00000000000000000000000000000101 //00000000000000000000000001111110 //00000000000000000000000010000011 //11111011 - c //整形提升后 //11111111111111111111111110000011 - 補(bǔ)碼 //11111111111111111111111110000010 - 反碼 //10000000000000000000000001111101 - 原碼 printf("%d/n", a + b);}
如果某個(gè)操作符的各個(gè)操作數(shù)屬于不同的類型,那么除非其中一個(gè)操作數(shù)的轉(zhuǎn)換為另一個(gè)操作數(shù)的類型,否則操作就無法進(jìn)行。
下面的層次體系稱為尋常算術(shù)轉(zhuǎn)換:
long double
double
float
unsigned long int
long int
unsigned int
int
如果某個(gè)操作數(shù)的類型在上面這個(gè)列表中排名較低,那么首先要轉(zhuǎn)換為另外一個(gè)操作數(shù)的類型后執(zhí)行運(yùn)算。
復(fù)雜表達(dá)式的求值有三個(gè)影響的因素。
兩個(gè)相鄰的操作符先執(zhí)行哪個(gè)?取決于他們的優(yōu)先級(jí)。如果兩者的優(yōu)先級(jí)相同,取決于他們的結(jié)合性。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/123614.html
摘要:目錄移位操作符移位操作符位操作符位操作符移位操作符分為左移操作符和右移操作符。左移操作符移位規(guī)則左邊拋棄,右邊補(bǔ)。算數(shù)移位和邏輯移位。 目錄 1、移位操作符 2、位操作符 1、移位操作符 分為左移操作符(>>)和右移操作符(1邏輯移位的得到的是什么吧~ ? 因?yàn)樽罡呶皇?,所以最后的結(jié)果就...
摘要:一維卷積常用于序列模型,自然語言處理領(lǐng)域。三維卷積這里采用代數(shù)的方式對(duì)三維卷積進(jìn)行介紹,具體思想與一維卷積二維卷積相同。 由于計(jì)算機(jī)視覺的大紅大紫,二維卷積的用處范圍最廣。因此本文首先介紹二維卷積,之后再介紹一維卷積與三維卷積的具體流程,并描述其各自的具體應(yīng)用。1、二維卷積?? ? 圖中的輸入的數(shù)據(jù)維度為 14 × 14 ,過濾器大小為 5 × 5,二者做卷積,輸出的數(shù)據(jù)維度為 10 × 1...
摘要:概述前面已經(jīng)講解了關(guān)于的非公平鎖模式,關(guān)于非公平鎖,內(nèi)部其實(shí)告訴我們誰先爭(zhēng)搶到鎖誰就先獲得資源,下面就來分析一下公平鎖內(nèi)部是如何實(shí)現(xiàn)公平的如果沒有看過非公平鎖的先去了解下非公平鎖,因?yàn)檫@篇文章前面不會(huì)講太多內(nèi)部結(jié)構(gòu),直接會(huì)對(duì)源碼進(jìn)行分析前文 概述 前面已經(jīng)講解了關(guān)于AQS的非公平鎖模式,關(guān)于NonfairSync非公平鎖,內(nèi)部其實(shí)告訴我們誰先爭(zhēng)搶到鎖誰就先獲得資源,下面就來分析一下公平...
閱讀 2763·2021-11-24 10:23
閱讀 1162·2021-11-17 09:33
閱讀 2511·2021-09-28 09:41
閱讀 1426·2021-09-22 15:55
閱讀 3649·2019-08-29 16:32
閱讀 1915·2019-08-29 16:25
閱讀 1063·2019-08-29 11:06
閱讀 3430·2019-08-29 10:55