位運(yùn)算和sizeof運(yùn)算符
C語言中提供了一些運(yùn)算符可以直接操作整數(shù)的位,稱為位運(yùn)算,因此位運(yùn)算中的操作數(shù)都必須是整型的。位運(yùn)算的效率是比較高的,而且位運(yùn)算運(yùn)用好的話會(huì)達(dá)到意想不到的效果。位運(yùn)算主要有6種:與(&),或(|),取反(~),異或(^),左移(<<),右移(>>)。
1.位運(yùn)算中的類型轉(zhuǎn)換
位運(yùn)算都必須進(jìn)行Integer Promotion。在進(jìn)行運(yùn)算之前,都必須將char型、short型的數(shù)據(jù)轉(zhuǎn)換為int或者unsigned int型再參與運(yùn)算。
如下面這段程序:
#include<stdio.h>int main(void){ unsigned char c=0xfc; unsigned int i=~c; printf("0x%x/n",i); return 0;}
在對c取反之前,先將c提升為int型,則為0x000000fc,取反之后結(jié)果就是0xffffff03,所以程序輸出結(jié)果是0xffffff03,而不是0x00000003.
2.異或運(yùn)算的一些特性。
a^0=a,a^a=0這兩個(gè)特性是異或運(yùn)算最常用的特性。
利用這個(gè)特性可以不借助臨時(shí)變量就可以交換兩個(gè)整數(shù)
#include<stdio.h>int main(void){ int a=3; int b=2; a=a^b; b=a^b; a=a^b; printf("%d %d/n",a,b); return 0;}
不借助臨時(shí)變量交換兩個(gè)數(shù)據(jù)還可以用另外一種方法。
a=a+b;
b=a-b;
a=a-b;
這兩種方法各有優(yōu)點(diǎn)和缺點(diǎn),位運(yùn)算只能用于交換整數(shù),而第二種可能會(huì)發(fā)生溢出。
3.sizeof運(yùn)算符
sizeof是一個(gè)特殊的運(yùn)算符,它有兩種形式:sizeof 表達(dá)式和sizeof (類型名).對于sizeof運(yùn)算符要注意幾點(diǎn):
1)如果是表達(dá)式的話,括號(hào)可以省略,但是對于類型,括號(hào)不能省;
2)sizeof求算的是所占的空間,如果作用于表達(dá)式,這個(gè)表達(dá)式是不進(jìn)行求值的,只根據(jù)類型轉(zhuǎn)換求得表達(dá)式的類型,而表達(dá)式的類型在編譯時(shí)就可以確定。
#include<stdio.h>int main(void){ int i=1; int j; j=sizeof i++; printf("%d %d/n",i,j); return 0;}
程序執(zhí)行結(jié)果為:
1 4
Press any key to continue
可以看出i的值并沒有改變,可知表達(dá)式i++并沒有進(jìn)行求值。
再看下面這個(gè)程序:
#include <stdio.h>int main(int argc, char *argv[]){ char ch ='a'; int i =10; printf("%d/n",sizeof i+ch); return 0;}
執(zhí)行結(jié)果為:
101
在有二元運(yùn)算符的表達(dá)式中,必須加括號(hào),否則sizeof只會(huì)對第一個(gè)操作數(shù)進(jìn)行空間計(jì)算。由于ch的整形值為97,加上4,便是101了。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點(diǎn)
疑難解答
圖片精選