在日常的學習、工作、生活中,肯定對各類范文都很熟悉吧。范文怎么寫才能發(fā)揮它最大的作用呢?下面是小編幫大家整理的優(yōu)質(zhì)范文,僅供參考,大家一起來看看吧。
c語言位運算符解釋 c中的位運算符篇一
一個比特(bit)位只有 0 和 1 兩個取值,只有參與&運算的兩個位都為 1 時,結(jié)果才為 1,否則為 0。例如1&1為 1,0&0為 0,1&0也為 0,這和邏輯運算符&&非常類似。
c語言中不能直接使用二進制,&兩邊的操作數(shù)可以是十進制、八進制、十六進制,它們在內(nèi)存中最終都是以二進制形式存儲,&就是對這些內(nèi)存中的'二進制位進行運算。其他的位運算符也是相同的道理。
例如,9 & 5可以轉(zhuǎn)換成如下的運算:
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
& 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0001 (1 在內(nèi)存中的存儲)
也就是說,按位與運算會對參與運算的兩個數(shù)的所有二進制位進行&運算,9 & 5的結(jié)果為 1。
又如,-9 & 5可以轉(zhuǎn)換成如下的運算:
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
& 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-9 & 5的結(jié)果是 5。
關(guān)于正數(shù)和負數(shù)在內(nèi)存中的存儲形式,我們已在教程《整數(shù)在內(nèi)存中是如何存儲的》中進行了講解。
再強調(diào)一遍,&是根據(jù)內(nèi)存中的二進制位進行運算的,而不是數(shù)據(jù)的二進制形式;其他位運算符也一樣。以-9&5為例,-9 的在內(nèi)存中的存儲和 -9 的二進制形式截然不同:
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
-0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (-9 的二進制形式,前面多余的 0 可以抹掉)
按位與運算通常用來對某些位清 0,或者保留某些位。例如要把 n 的高 16 位清 0 ,保留低 16 位,可以進行n & 0xffff運算(0xffff 在內(nèi)存中的存儲形式為 0000 0000 -- 0000 0000 -- 1111 1111 -- 1111 1111)。
【實例】對上面的分析進行檢驗。
00001. #include
00002.
00003. int main(){
00004. int n = 0x8fa6002d;
00005. printf("%d, %d, %x ", 9 & 5, -9 & 5, n & 0xffff);
00006. return 0;
00007. }
運行結(jié)果:
1, 5, 2d
參與|運算的兩個二進制位有一個為 1 時,結(jié)果就為 1,兩個都為 0 時結(jié)果才為 0。例如1|1為1,0|0為0,1|0為1,這和邏輯運算中的||非常類似。
例如,9 | 5可以轉(zhuǎn)換成如下的運算:
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
| 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1101 (13 在內(nèi)存中的存儲)
9 | 5的結(jié)果為 13。
又如,-9 | 5可以轉(zhuǎn)換成如下的運算:
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
| 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
-9 | 5的結(jié)果是 -9。
按位或運算可以用來將某些位置 1,或者保留某些位。例如要把 n 的高 16 位置 1,保留低 16 位,可以進行n | 0xffff0000運算(0xffff0000 在內(nèi)存中的存儲形式為 1111 1111 -- 1111 1111 -- 0000 0000 -- 0000 0000)。
【實例】對上面的分析進行校驗。
00001. #include
00002.
00003. int main(){
00004. int n = 0x2d;
00005. printf("%d, %d, %x ", 9 | 5, -9 | 5, n | 0xffff0000);
00006. return 0;
00007. }
運行結(jié)果:
13, -9, ffff002d
參與^運算兩個二進制位不同時,結(jié)果為 1,相同時結(jié)果為 0。例如0^1為1,0^0為0,1^1為0。
例如,9 ^ 5可以轉(zhuǎn)換成如下的運算:
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
^ 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1100 (12 在內(nèi)存中的存儲)
9 ^ 5的結(jié)果為 12。
又如,-9 ^ 5可以轉(zhuǎn)換成如下的運算:
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
^ 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101 (5 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0010 (-14 在內(nèi)存中的存儲)
-9 ^ 5的結(jié)果是 -14。
按位異或運算可以用來將某些二進制位反轉(zhuǎn)。例如要把 n 的高 16 位反轉(zhuǎn),保留低 16 位,可以進行n ^ 0xffff0000運算(0xffff0000 在內(nèi)存中的存儲形式為 1111 1111 -- 1111 1111 -- 0000 0000 -- 0000 0000)。
【實例】對上面的分析進行校驗。
00001. #include
00002.
00003. int main(){
00004. unsigned n = 0x0a07002d;
00005. printf("%d, %d, %x ", 9 ^ 5, -9 ^ 5, n ^ 0xffff0000);
00006. return 0;
00007. }
運行結(jié)果:
12, -14, f5f8002d
取反運算符~為單目運算符,右結(jié)合性,作用是對參與運算的二進制位取反。例如~1為0,~0為1,這和邏輯運算中的!非常類似。。
例如,~9可以轉(zhuǎn)換為如下的運算:
~ 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0110 (-10 在內(nèi)存中的存儲)
所以~9的結(jié)果為 -10。
例如,~-9可以轉(zhuǎn)換為如下的運算:
~ 1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1000 (9 在內(nèi)存中的存儲)
所以~-9的結(jié)果為 8。
【實例】對上面的分析進行校驗。
00001. #include
00002.
00003. int main(){
00004. printf("%d, %d ", ~9, ~-9 );
00005. return 0;
00006. }
運行結(jié)果:
-10, 8
左移運算符<<用來把操作數(shù)的各個二進制位全部左移若干位,高位丟棄,低位補0。
例如,9<<3可以轉(zhuǎn)換為如下的運算:
<< 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0100 1000 (72 在內(nèi)存中的存儲)
所以9<<3的結(jié)果為 72。
又如,(-9)<<3可以轉(zhuǎn)換為如下的運算:
<< 1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1011 1000 (-72 在內(nèi)存中的存儲)
所以(-9)<<3的結(jié)果為 -72
如果數(shù)據(jù)較小,被丟棄的高位不包含 1,那么左移 n 位相當于乘以 2 的 n 次方。
【實例】對上面的結(jié)果進行校驗。
00001. #include
00002.
00003. int main(){
00004. printf("%d, %d ", 9<<3, (-9)<<3 );
00005. return 0;
00006. }
運行結(jié)果:
72, -72
右移運算符>>用來把操作數(shù)的各個二進制位全部右移若干位,低位丟棄,高位補 0 或 1。如果數(shù)據(jù)的最高位是 0,那么就補 0;如果最高位是 1,那么就補 1。
例如,9>>3可以轉(zhuǎn)換為如下的運算:
>> 0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001 (9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0001 (1 在內(nèi)存中的存儲)
所以9>>3的結(jié)果為 1。
又如,(-9)>>3可以轉(zhuǎn)換為如下的運算:
>> 1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111 (-9 在內(nèi)存中的存儲)
-----------------------------------------------------------------------------------
1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 1110 (-2 在內(nèi)存中的存儲)
所以(-9)>>3的結(jié)果為 -2
如果被丟棄的低位不包含 1,那么右移 n 位相當于除以 2 的 n 次方(但被移除的位中經(jīng)常會包含 1)。
【實例】對上面的結(jié)果進行校驗。
00001. #include
00002.
00003. int main(){
00004. printf("%d, %d ", 9>>3, (-9)>>3 );
00005. return 0;
00006. }
運行結(jié)果:
1, -2
c語言位運算符解釋 c中的位運算符篇二
& 按位與
| 按位或
^ 按位異或
~ 取反
<< 左移
>> 右移
按位與運算符"&"是雙目運算符。其功能是參與運算的兩數(shù)各對應(yīng)的二進位相與。只有對應(yīng)的兩個二進位均為1時,結(jié)果位才為1 ,否則為0。參與運算的數(shù)以補碼方式出現(xiàn)。
例如:9&5可寫算式如下: 00001001 (9的二進制補碼)&00000101 (5的二進制補碼) 00000001 (1的二進制補碼)可見9&5=1。
按位與運算通常用來對某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a&255 運算 ( 255 的二進制數(shù)為0000000011111111)。
main(){
int a=9,b=5,c;
c=a&b;
printf("a=%d/nb=%d/nc=%d/n",a,b,c);
}
按位或運算符“|”是雙目運算符。其功能是參與運算的兩數(shù)各對應(yīng)的二進位相或。只要對應(yīng)的二個二進位有一個為1時,結(jié)果位就為1。參與運算的兩個數(shù)均以補碼出現(xiàn)。
例如:9|5可寫算式如下: 00001001|00000101
00001101 (十進制為13)可見9|5=13
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d/nb=%d/nc=%d/n",a,b,c);
}
按位異或運算符“^”是雙目運算符。其功能是參與運算的兩數(shù)各對應(yīng)的二進位相異或,當兩對應(yīng)的二進位相異時,結(jié)果為1。參與運算數(shù)仍以補碼出現(xiàn),例如9^5可寫成算式如下: 00001001^00000101 00001100 (十進制為12)。
main(){
int a=9;
a=a^15;
printf("a=%d/n",a);
}
求反運算符~為單目運算符,具有右結(jié)合性。 其功能是對參與運算的數(shù)的各二進位按位求反。例如~9的運算為: ~(0000000000001001)結(jié)果為:1111111111110110。
左移運算符“<<”是雙目運算符。其功能把“<< ”左邊的運算數(shù)的各二進位全部左移若干位,由“<<”右邊的數(shù)指定移動的位數(shù),高位丟棄,低位補0。例如: a<<4 指把a的各二進位向左移動4位。如a=00000011(十進制3),左移4位后為00110000(十進制48)。
右移運算符“>>”是雙目運算符。其功能是把“>> ”左邊的運算數(shù)的各二進位全部右移若干位,“>>”右邊的數(shù)指定移動的位數(shù)。
例如:設(shè) a=15,a>>2 表示把000001111右移為00000011(十進制3)。 應(yīng)該說明的是,對于有符號數(shù),在右移時,符號位將隨同移動。當為正數(shù)時, 最高位補0,而為負數(shù)時,符號位為1,最高位是補0或是補1 取決于編譯系統(tǒng)的規(guī)定。turbo c和很多系統(tǒng)規(guī)定為補1。
main(){
unsigned a,b;
printf("input a number: ");
scanf("%d",&a);
b=a>>5;
b=b&15;
printf("a=%d/tb=%d/n",a,b);
}
請再看一例!
main(){
char a='a',b='b';
int p,c,d;
p=a;
p=(p<<8)|b;
d=p&0xff;
c=(p&0xff00)>>8;
printf("a=%d/nb=%d/nc=%d/nd=%d/n",a,b,c,d);
}
【本文地址:http://www.aiweibaby.com/zuowen/2722934.html】