- 相關(guān)推薦
C語言的移位操作符使用方法
位移位運(yùn)算符是將數(shù)據(jù)看成二進(jìn)制數(shù),對其進(jìn)行向左或向右移動若干位的運(yùn)算。位移位運(yùn)算符分為左移和右移兩種,均為雙目運(yùn)算符。第一運(yùn)算對象是移位對象,第二個運(yùn)算對象是所移的二進(jìn)制位數(shù)。以下是小編為大家搜索整理的C語言的移位操作符使用方法,希望能給大家?guī)韼椭?
移位時,移出的位數(shù)全部丟棄,移出的空位補(bǔ)入的數(shù)與左移還是右移花接木有關(guān)。如果是左移,則規(guī)定補(bǔ)入的數(shù)全部是0;如果是右移,還與被移位的數(shù)據(jù)是否帶符號有關(guān)。若是不帶符號數(shù),則補(bǔ)入的數(shù)全部為0;若是帶符號數(shù),則補(bǔ)入的數(shù)全部等于原數(shù)的最左端位上的原數(shù)(即原符號位)。具體移位規(guī)則如下所示。
位移位運(yùn)算符的優(yōu)先級如下:
·算術(shù)運(yùn)算符 優(yōu)先于 位移位運(yùn)算符 優(yōu)先于 關(guān)系運(yùn)算符
·位移位運(yùn)算符是同級別的,結(jié)合性是自左向右
例如,設(shè)無符號短整型變量a為0111(對應(yīng)二進(jìn)制數(shù)為0000000001001001),
則:a<<3 結(jié)果為01110(對應(yīng)二進(jìn)制數(shù)為0000001001001000),a不變
a>>4 結(jié)果為04 (對應(yīng)二進(jìn)制數(shù)為0000000000000100),a不變
又如,設(shè)短整型變量a為-4(對應(yīng)二進(jìn)制數(shù)為 1111111111111100),
則:a<<3 結(jié)果為-32(對應(yīng)二進(jìn)制數(shù)為1111111111100000),a不變
a>>4 結(jié)果為-1(對應(yīng)二進(jìn)制數(shù)為1111111111111111),a不變
C語言里的左移和右移運(yùn)算
2006-09-30 13:52
先說左移,左移就是把一個數(shù)的所有位都向左移動若干位,在C中用<<運(yùn)算符.例如:
int i = 1;
i = i << 2; //把i里的值左移2位
也就是說,1的2進(jìn)制是000...0001(這里1前面0的個數(shù)和int的位數(shù)有關(guān),32位機(jī)器,gcc里有31個0),左移2位之后變成 000... 0100,也就是10進(jìn)制的4,所以說左移1位相當(dāng)于乘以2,那么左移n位就是乘以2的n次方了(有符號數(shù)不完全適用,因為左移有可能導(dǎo)致符號變化,下面解釋原因)
需要注意的一個問題是int類型最左端的符號位和移位移出去的情況.我們知道,int是有符號的整形數(shù),最左端的1位是符號位,即0正1負(fù),那么移位的時候就會出現(xiàn)溢出,例如:
int i = 0x40000000; //16進(jìn)制的40000000,為2進(jìn)制的01000000...0000
i = i << 1;
那么,i在左移1位之后就會變成0x80000000,也就是2進(jìn)制的100000...0000,符號位被置1,其他位全是0,變成了int類型所能表示的最小值,32位的int這個值是-2147483648,溢出.如果再接著把i左移1位會出現(xiàn)什么情況呢?在C語言中采用了丟棄最高位的處理方法,丟棄了1之后,i的值變成了0.
左移里一個比較特殊的情況是當(dāng)左移的位數(shù)超過該數(shù)值類型的最大位數(shù)時,編譯器會用左移的位數(shù)去模類型的最大位數(shù),然后按余數(shù)進(jìn)行移位,如:
int i = 1, j = 0x80000000; //設(shè)int為32位
i = i << 33; // 33 % 32 = 1 左移1位,i變成2
j = j << 33; // 33 % 32 = 1 左移1位,j變成0,最高位被丟棄
在用gcc編譯這段程序的時候編譯器會給出一個warning,說左移位數(shù)>=類型長度.那么實際上i,j移動的就是1位,也就是33%32 后的余數(shù).在gcc下是這個規(guī)則,別的編譯器是不是都一樣現(xiàn)在還不清楚.
總之左移 就是: 丟棄最高位,0補(bǔ)最低位
再說右移,明白了左移的道理,那么右移就比較好理解了.
右移的概念和左移相反,就是往右邊挪動若干位,運(yùn)算符是>>.
右移對符號位的處理和左移不同,對于有符號整數(shù)來說,比如int類型,右移會保持符號位不變,例如:
int i = 0x80000000;
i = i >> 1; //i的值不會變成0x40000000,而會變成0xc0000000
就是說,符號位向右移動后,正數(shù)的話補(bǔ)0,負(fù)數(shù)補(bǔ)1,也就是匯編語言中的算術(shù)右移.同樣當(dāng)移動的位數(shù)超過類型的長度時,會取余數(shù),然后移動余數(shù)個位.
負(fù)數(shù)10100110 >>5(假設(shè)字長為8位),則得到的是 11111101
總之,在C中,左移是邏輯/算術(shù)左移(兩者完全相同),右移是算術(shù)右移,會保持符號位不變 .實際應(yīng)用中可以根據(jù)情況用左/右移做快速的乘 /除運(yùn)算,這樣會比循環(huán)效率高很多.
在很多系統(tǒng)程序中常要求在位(bit)一級進(jìn)行運(yùn)算或處理。C語言提供了位運(yùn)算的功能, 這使得C語言也能像匯編語言一樣用來編寫系統(tǒng)程序。
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
操作符 作用
────────────────────────────
& 位邏輯與
| 位邏輯或
^ 位邏輯異或
- 位邏輯反
>> 右移
<< 左移
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
按位運(yùn)算是對字節(jié)或字中的實際位進(jìn)行檢測、設(shè)置或移位, 它只適用于字符型和整數(shù)型變量以及它們的變體, 對其它數(shù)據(jù)類型不適用。
我們要注意區(qū)分位運(yùn)算和邏輯運(yùn)算。
1.按位與運(yùn)算
按位與運(yùn)算符"&"是雙目運(yùn)算符。其功能是參與運(yùn)算的兩數(shù)各對應(yīng)的二進(jìn)位相與。只有對應(yīng)的兩個二進(jìn)位均為1時,結(jié)果位才為1 ,否則為0。參與運(yùn)算的數(shù)以補(bǔ)碼方式出現(xiàn)。
例如:9&5可寫算式如下: 00001001 (9的二進(jìn)制補(bǔ)碼)&00000101 (5的二進(jìn)制補(bǔ)碼) 00000001 (1的二進(jìn)制補(bǔ)碼)可見9&5=1。
按位與運(yùn)算通常用來對某些位清0或保留某些位。例如把a(bǔ) 的高八位清 0 , 保留低八位, 可作 a&255 運(yùn)算 ( 255 的二進(jìn)制數(shù)為0000000011111111)。
main(){
int a=9,b=5,c;
c=a&b;
printf("a=%d b=%d c=%d ",a,b,c);
}
2. 按位或運(yùn)算
按位或運(yùn)算符“|”是雙目運(yùn)算符。其功能是參與運(yùn)算的兩數(shù)各對應(yīng)的二進(jìn)位相或。只要對應(yīng)的二個二進(jìn)位有一個為1時,結(jié)果位就為1。參與運(yùn)算的兩個數(shù)均以補(bǔ)碼出現(xiàn)。
例如:9|5可寫算式如下: 00001001|00000101
00001101 (十進(jìn)制為13)可見9|5=13
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d b=%d c=%d ",a,b,c);
}
3. 按位異或運(yùn)算
按位異或運(yùn)算符“^”是雙目運(yùn)算符。其功能是參與運(yùn)算的兩數(shù)各對應(yīng)的二進(jìn)位相異或,當(dāng)兩對應(yīng)的二進(jìn)位相異時,結(jié)果為1。參與運(yùn)算數(shù)仍以補(bǔ)碼出現(xiàn),例如 9^5可寫成算式如下: 00001001^00000101 00001100 (十進(jìn)制為12)
main(){
int a=9;
a=a^15;
printf("a=%d ",a);
}
4. 求反運(yùn)算
求反運(yùn)算符~為單目運(yùn)算符,具有右結(jié)合性。 其功能是對參與運(yùn)算的數(shù)的各二進(jìn)位按位求反。例如~9的運(yùn)算為: ~(0000000000001001)結(jié)果為:1111111111110110
5. 左移運(yùn)算
左移運(yùn)算符“<<”是雙目運(yùn)算符。其功能把“<< ”左邊的運(yùn)算數(shù)的各二進(jìn)位全部左移若干位,由“<<”右邊的數(shù)指定移動的位數(shù),高位丟棄,低位補(bǔ)0。例如: a<<4 指把a(bǔ)的各二進(jìn)位向左移動4位。如a=00000011(十進(jìn)制3),左移4位后為00110000(十進(jìn)制48)。
6. 右移運(yùn)算
右移運(yùn)算符“>>”是雙目運(yùn)算符。其功能是把“>> ”左邊的運(yùn)算數(shù)的各二進(jìn)位全部右移若干位,“>>”右邊的數(shù)指定移動的位數(shù)。例如:設(shè) a=15,a>>2 表示把000001111右移為00000011(十進(jìn)制3)。應(yīng)該說明的是,對于有符號數(shù),在右移時,符號位將隨同移動。當(dāng)為正數(shù)時, 最高位補(bǔ)0,而為負(fù)數(shù)時,符號位為1,最高位是補(bǔ)0或是補(bǔ)1 取決于編譯系統(tǒng)的規(guī)定。
main(){
unsigned a,b;
printf("input a number: ");
scanf("%d",&a);
b=a>>5;
b=b&15;
printf("a=%d b=%d ",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 b=%d c=%d d=%d ",a,b,c,d);
}
當(dāng)進(jìn)行按位與或時,最好使用16進(jìn)制,在程序中這樣表示:0x01 表示0000 0001
所以,字符類型a的最高位強(qiáng)制1可以這樣:a=a|0x80。其他的可以依次類推!
【C語言的移位操作符使用方法】相關(guān)文章:
C語言socket編程使用方法06-20
C++operator操作符技巧09-15
C語言socket編程使用方法簡介07-29
c語言中指針的使用方法10-12
C語言和C++的分別06-18
C語言的結(jié)構(gòu)10-14
C語言考點(diǎn)精選06-29
C語言的應(yīng)用05-29
C語言試題08-02
什么是C語言07-27