對C語言中sizeof細節(jié)的三點分析介紹
更新時間:2013年07月11日 11:35:50 作者:
以下是對C語言中sizeof的細節(jié)進行了詳細的分析介紹,需要的朋友可以參考下
1.sizeof是運算符,跟加減乘除的性質(zhì)其實是一樣的,在編譯的時候進行執(zhí)行,而不是在運行時才執(zhí)行。
那么如果編程中驗證這一點呢?ps:這是前兩天朋友淘寶面試的一道題,小編理解:
復(fù)制代碼 代碼如下:
#include<iostream>
using namespace std;
int main()
{
int i=1;
cout<<i<<endl;
sizeof(++i);
cout<<i<<endl;
return 1;
}
輸入結(jié)果為 1
1
sizeof中的++i 的副作用并沒有顯示出來,原因只可能有一個,在編譯的時候sizeof執(zhí)行以后將++i 處理了,++i 的副作用因此被消除了。如果sizeof 是在運行時進行的話,則肯定要注意++i 。實際上sizeof的實現(xiàn)應(yīng)該是用宏來做的,宏在編譯時進行執(zhí)行。具體實現(xiàn)可以參考下面。
2.sizeof('a')在C語言中的結(jié)果是4,在C++中結(jié)果是1,看過某篇文章說C中sizeof側(cè)重于“數(shù)”,而C++中sizeof更側(cè)重于“字符”。
3.文章中講了兩個用宏實現(xiàn)sizeof的經(jīng)典應(yīng)用
復(fù)制代碼 代碼如下:
//適用于非數(shù)組
#define _sizeof(T) ((size_t)((T*)0 + 1))
//適用于數(shù)組
#define array_sizeof(T) ((size_t)(&T+1)-(size_t)(&T))
先舉兩個小例子說明兩個宏的應(yīng)用,對于第一個如 _sizeof(int); 的結(jié)果就是4;對于第二個先聲明一個大小為4的數(shù)組int a[4];那么array_sizeof(a)結(jié)果為16.
對于非數(shù)組的宏定義,先是將0轉(zhuǎn)換為T*類型的指針?biāo)赶虻牡刂罚ù藭r地址為0)。然后對T類型的地址加1,相當(dāng)于加上了T類型的大?。吹玫搅朔菙?shù)組T的大小)。前面的size_t只是將地址轉(zhuǎn)化為int型的整數(shù)返回。
一個簡單的例子:int* p; p=p+1; --------p是一個int*類型的指針, p+1在地址空間上相當(dāng)于加上了4個字節(jié)。
對于數(shù)組的宏定義,類似于非數(shù)組的宏定義,為了方便理解,這里可以把數(shù)組T看成一個用戶自定義的類型,&T表示數(shù)組類型的指針,對于數(shù)組類型指針加1相當(dāng)于在地址上加上了該數(shù)組大小。由于是用戶自定義的類型所以不能強制將0轉(zhuǎn)化為數(shù)組類型的地址,只能用加1后的地址減去之前的地址,得到的差值就是數(shù)組本身所占的字節(jié)大小。
相關(guān)文章
詳解C語言中accept()函數(shù)和shutdown()函數(shù)的使用
這篇文章主要介紹了詳解C語言中accept()函數(shù)和shutdown()函數(shù)的使用,用來操作socket相關(guān)的網(wǎng)絡(luò)通信,需要的朋友可以參考下2015-09-09