成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

C語言基礎(chǔ)之操作符詳解

snowell / 1161人閱讀

摘要:語言基礎(chǔ)之操作符詳解操作符的分類算術(shù)操作符移位操作符位操作符邏輯操作符逗號(hào)表達(dá)式表達(dá)式求值隱式類型轉(zhuǎn)換算術(shù)轉(zhuǎn)換操作符的屬性今天就帶各位大佬來了解一波語言的操作符。


xwg今天就帶各位大佬來了解一波C語言的操作符。

操作符的分類

常見的操作符分別如下:

  1. 算術(shù)操作符
  2. 移位操作符
  3. 位操作符
  4. 邏輯操作符
  5. 逗號(hào)表達(dá)式

算術(shù)操作符

算術(shù)操作符是我們最常用的操作符:+ - * / %
注:

  1. 除了 % 操作符之外,其他的幾個(gè)操作符可以作用于整數(shù)和浮點(diǎn)數(shù)。
  2. 對(duì)于 / 操作符如果兩個(gè)操作數(shù)都為整數(shù),執(zhí)行整數(shù)除法,而只要有浮點(diǎn)數(shù)執(zhí)行的就是浮點(diǎn)數(shù)除法。
  3. % 操作符的兩個(gè)操作數(shù)必須為整數(shù)。返回的是整除之后的余數(shù)。

移位操作符

移位操作符分為左移操作符和右移操作符,移位操作符的操作對(duì)象只能是整數(shù),且所謂的移位是對(duì)于整數(shù)的二進(jìn)制位進(jìn)行移位:
左移操作符:<<
右移操作符:>>

  1. 左移操作符:
    移位規(guī)則:左邊拋棄,右邊補(bǔ)0
  2. 右移操作符:
    移位規(guī)則:
    2.1 邏輯移位
    左邊用0填充,右邊丟棄
    2.2算術(shù)移位
    左邊用原該值的符號(hào)位填充,右邊丟棄
    注:大部分編譯器右移都是執(zhí)行算術(shù)右移。

注:對(duì)于移位運(yùn)算符,不要移動(dòng)負(fù)數(shù)位,這個(gè)是標(biāo)準(zhǔn)未定義的。

位操作符

位操作符有:

& —— 按位與
| —— 按位或
^ —— 按位異或

位操作符的操作數(shù)必須是整數(shù),且是對(duì)其二進(jìn)制的補(bǔ)碼進(jìn)行操作。
異或的基本性質(zhì):

  1. 0異或上任何數(shù)為其本身:0^2=2
  2. 任何數(shù)異或上其本身等于0:2^2=0

例:不創(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)表達(dá)式是用逗號(hào)隔開的多個(gè)表達(dá)式:
exp1, exp2, exp3, …expN
逗號(hào)表達(dá)式,從左向右依次執(zhí)行,整個(gè)表達(dá)式的結(jié)果是最后一個(gè)表達(dá)式的結(jié)果。

表達(dá)式求值

表達(dá)式求值的順序一部分是由操作符的優(yōu)先級(jí)和結(jié)合性決定,但是,有些表達(dá)式的操作數(shù)在求值的過程中可能需要轉(zhuǎn)換為其他類型。

隱式類型轉(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);}

算術(shù)轉(zhuǎn)換

如果某個(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è)影響的因素。

  1. 操作符的優(yōu)先級(jí)
  2. 操作符的結(jié)合性
  3. 是否控制求值順序。

兩個(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ān)文章

  • C語言移位作符、位作符詳解

    摘要:目錄移位操作符移位操作符位操作符位操作符移位操作符分為左移操作符和右移操作符。左移操作符移位規(guī)則左邊拋棄,右邊補(bǔ)。算數(shù)移位和邏輯移位。 目錄 1、移位操作符 2、位操作符 1、移位操作符 分為左移操作符(>>)和右移操作符(1邏輯移位的得到的是什么吧~ ? 因?yàn)樽罡呶皇?,所以最后的結(jié)果就...

    NeverSayNever 評(píng)論0 收藏0
  • 卷積神經(jīng)網(wǎng)絡(luò)(CNN)一維卷積、二維卷積、三維卷積詳解

    摘要:一維卷積常用于序列模型,自然語言處理領(lǐng)域。三維卷積這里采用代數(shù)的方式對(duì)三維卷積進(jìn)行介紹,具體思想與一維卷積二維卷積相同。 由于計(jì)算機(jī)視覺的大紅大紫,二維卷積的用處范圍最廣。因此本文首先介紹二維卷積,之后再介紹一維卷積與三維卷積的具體流程,并描述其各自的具體應(yīng)用。1、二維卷積?? ? 圖中的輸入的數(shù)據(jù)維度為 14 × 14 ,過濾器大小為 5 × 5,二者做卷積,輸出的數(shù)據(jù)維度為 10 × 1...

    renweihub 評(píng)論0 收藏0
  • 圖解AQS原理ReentrantLock詳解-公平鎖

    摘要:概述前面已經(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)搶到鎖誰就先獲得資源,下面就來分析一下公平...

    Taonce 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<