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