《 C 語言的一些“騷操作”及其深層理解》之關(guān)于變量互換與sizeof
關(guān)于變量互換
初學(xué)C語言的時候,有一個小編程題我們應(yīng)該都記得,就是變量互換。
int a,b;
int temp;
temp=a;
a=b;
b=temp;
變量a與b的值互換,在這過程中一定需要一個中間變量temp作為中轉(zhuǎn)。不用這個中間變量能不能實現(xiàn)?請看下面的代碼:
int a,b;
a=a+b;
b=a-b;
a=a-b;
可以說上面代碼有點(diǎn)小巧妙,那么下面的代碼就真正是巧妙了:
int a,b;
a=a^b;
b=a^b;
a=a^b;
異或運(yùn)算有一個性質(zhì)叫自反性,這個可以實現(xiàn)很多巧妙的操作,大家可以深入研究一下。(異或位運(yùn)算比上面的加減法更嚴(yán)謹(jǐn),因為加減法是可能會溢出的)
關(guān)于sizeof
C語言中的sizeof我們應(yīng)該是非常熟悉的,它的作用就是用來計算一個變量或類型所占用的字節(jié)數(shù)。
sizeof(int) //如果是32位CPU平臺,值為4,即4個字節(jié)
int a; sizeof(a) //同上
sizeof(struct ...) //計算某結(jié)構(gòu)體的大小
這個很簡單,我們再來看下面的代碼:
char *pc="abc";
sizeof(pc) //指針的sizeof等于多少?
sizeof(*pc) //指針指向的單元的sizeof等于多少?
pc用來指向char類型的變量。pc本身是一個指針類型,在32位平臺上sizeof(pc)的值為4,即指針類型占用4個字節(jié)(與CPU平臺有關(guān))。*pc是pc所指向的變量,所以sizeof(*pc)的值為1。
好,還能理解吧,那我們再來看:
char a1[]="abcd";
sizeof(a1) //數(shù)組的sizeof等于多少?
void fun(char a1[]) //形參a1的sizeof等于多少?
{
//....
}
第一個sizeof(a1)等于5,因為它是一個數(shù)組(最后還有一個字符串結(jié)束符’\0’)。第二個sizeof(a1)等于4,形參中的a1不再是一個數(shù)組,而是一個指針。
好,下面的實例估計很多人沒見到過:
struct {} a,b,c;
sizeof(a) //空結(jié)構(gòu)體的sizeof等于多少?
空結(jié)構(gòu)體類型變量的大小是多少?這個問題似乎有些奇葩,沒什么實用性??战Y(jié)構(gòu)體有什么用?
這個問題可以揭示一些比較深層的問題,我們平時注意不到??战Y(jié)構(gòu)體的大小是1,即占用1個字節(jié)。當(dāng)我們的程序還僅僅是一個框架的時候,一些結(jié)構(gòu)體還只是一個空殼,只是拿一個struct的定義在那占位置而已,此時就涉及到空結(jié)構(gòu)體問題了。通常編譯器會給空結(jié)構(gòu)體分配1個字節(jié)的內(nèi)存空間。為什么?如果不分配空間,那程序中的多個同類型結(jié)構(gòu)體變量如何區(qū)分呢?比如a、b、c這三個變量,它們必須要被分配到不同的地址上去,各占1個字節(jié)的空間。
另外,因為sizeof有一個(),所以很多人想當(dāng)然的把它當(dāng)成一個函數(shù)。但其實它表達(dá)的是一個常數(shù)(運(yùn)算符),它的值在程序編譯期間就確定了。比如sizeof(i++),其中i為int類型,那么它的值就是4(32位平臺)。