前段時間接連到公司面試,其中這些公司包括什么華為,文思創新以及其他一些不出名的或忘了叫什么名字的垃圾公司,跑了不少路,做了不少的筆試題,感覺關于sizeof的運算相關的題目較多,自己將題做的一片糊涂,回來后親自寫了實驗來驗證。先帖代碼:






















char c ;




<<"sizeof c" <<sizeof(c)<<endl
<< "sizeof d[] = hello : " << sizeof(d) <<endl

<<"sizeof char r[100] : "<< sizeof(r) <<endl;

再帖轉載來的6條理論:
sizeof操作符的結果類型是size_t,它在頭文件中typedef為unsigned int類型。該類型保證能容納實現所建立的最大對象的字節大小。
1、若操作數具有類型char、unsigned char或signed char,其結果等于1。
ANSI C正式規定字符類型為1字節。
2、int、unsigned int 、short int、unsigned short 、long int 、unsigned long 、float、double、long double類型的sizeof 在ANSI C中沒有具體規定,大小依賴于實現,一般可能分別為4、4、2、2、4、4、4、8、10。
sizeof(c) = 1;
3、當操作數是指針時,sizeof依賴于編譯器。例如Microsoft C/C++7.0中,near類指針字節數為2,far、huge類指針字節數為4。一般Unix的指針字節數為4。
對于示例程序中的sizeof s,根據第3條,s是個字符串的指針,輸出為 sizeof s :4
4、當操作數具有數組類型時,其結果是數組的總字節數。
對于sizeof d[] ,根據第4條,d是數組類型,返回的是數組的字節數再加上末尾的null一字節,sizeof d[] = hello : 6
5、聯合類型操作數的sizeof是其最大字節成員的字節數。結構類型操作數的sizeof是這種類型對象的總字節數,包括任何墊補在內。
讓我們看如下結構:
struct {char b; double x;} a;
在某些機器上sizeof(a)=12,而一般sizeof(char)+ sizeof(double)=9。
這是因為編譯器在考慮對齊問題時,在結構中插入空位以控制各成員對象的地址對齊。如double類型的結構成員x要放在被4整除的地址。
對于sizeof t ,對齊后t的大小為20故輸出結果為sizeof t :20
6、如果操作數是函數中的數組形參或函數類型的形參,sizeof給出其指針的大小。
sizeof ch :4