C語言的運算符你了解嗎
前言
自學(xué)筆記,沒有歷史知識鋪墊(省略百度部分)C語言運算符的使用
一、算數(shù)運算符(數(shù)學(xué)運算)
+ -
左右數(shù)據(jù)同一數(shù)據(jù)類型
* / %
注意
乘/除法在很多CPU中無法實現(xiàn),或者需要多個CPU周期去實現(xiàn)嵌入式開發(fā)中,乘/除法可能需要第三方乘法庫才能實現(xiàn)乘/除法可能導(dǎo)致程序的移植性變差
%取模 場景:
獲取范圍數(shù)值時,如:int result=(x%100)+1; 則result值的范圍為[1.100]得到m進(jìn)制的個位數(shù),如8進(jìn)制個位數(shù): int a=x%8;介于取模的特性,可以用在循環(huán)數(shù)組結(jié)構(gòu)中獲取下標(biāo),0,1,2,3,0,1,2,3,0,1,2…
二、邏輯運算符(判斷真假)
|| &&
邏輯或 邏輯與
> >= < <=
大于 大于等于 小于 小于等于
!
非
? : 三元運算符
三元運算符
三、位運算符(重點)
<< 左移
運算場景:
左移1位,數(shù)據(jù)=數(shù)據(jù)2
m左移n位,m=m2ⁿ
>> 右移
運算場景:
右移1位,數(shù)據(jù)=數(shù)據(jù)/2
m右移n位,m=m/2ⁿ
注意:
signed和unsigned的右移動是不同的
signed修飾的變量的右移做while條件且變量為負(fù)數(shù)時,while會進(jìn)入死循環(huán)(因為最高位=1,是符號位,永遠(yuǎn)無法右移為0)
& | ^ ~ 與 或 異或 取反
& 與
屏蔽清零器 a=a | (~(0x1<<n))
bit中任意一位與0相&,該位都為0
場景:
int a=0x1234; //屏蔽低8位 a=a& 0xff00;
int a=0x1234; //清零器,清除bit第五位的高電平,轉(zhuǎn)為低電平,其他位不變 a=a & (~(0x1<<5));
| 或
保留/設(shè)置:設(shè)置高電平的方法,如設(shè)置指定位為高電平,其他位不變 a=a | (0x1<<n)
bit中任意一位與1相|,該位都為1
場景:
int a=3; //使用左移可以更方便快速的讓第五位bit處于高電平,而且不影響其他位(嵌入式中bit最右邊通常讀作第0位) a= a| (0x1<<5)
^ 異或
相同為0,不同為1
1.通常用于數(shù)據(jù)加密算法,AES SHA1等
2.數(shù)據(jù)交換(排序中的一種方法)
a=a^b;
b=a^b;
a=a^b;
~ 取反
按位取反
四、賦值運算符
= += -= &= ...
賦值運算實際上是組合運算的縮寫,非原子性操作,volatile內(nèi)存可見特性會失效(實際上執(zhí)行了兩步,只靠volatile無法解決)
五、內(nèi)存訪問符號
() 限制符/函數(shù)訪問符
1.限制符
(a+b)*c
1.函數(shù)訪問符
void fun();
[] 內(nèi)存訪問ID符
內(nèi)存訪問ID符(C語言中并不局限于數(shù)組的訪問,通過指針可以訪問整個內(nèi)存空間)
a[0] a[1]
{} 函數(shù)體限制符
函數(shù)體限制符
-> 地址訪問符
.變量訪問符
&取址符
&a;
*取值符
*a;
總結(jié)
本章主要為C語言運算符的使用
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++中可以接受任意多個參數(shù)的函數(shù)定義方法(詳解)
下面小編就為大家?guī)硪黄狢++中可以接受任意多個參數(shù)的函數(shù)定義方法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
怎么實現(xiàn)類的成員函數(shù)作為回調(diào)函數(shù)
不使用成員函數(shù),為了訪問類的成員變量,可以使用友元操作符(friend),在C++中將該函數(shù)說明為類的友元即可2013-10-10
詳解QListWidget如何實現(xiàn)自定義Item效果
這篇文章主要為大家介紹了如何通過QListWidget實現(xiàn)自定義Item效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2022-04-04

