一、sizeof的概念??
sizeof是C語言的一種單目操作符,如C語言的其他操作符++、--等,它并不是函數(shù)。??sizeof操作符以字節(jié)形式給出了其操作數(shù)的存儲(chǔ)大小。??操作數(shù)可以是一個(gè)表達(dá)式或括在括號(hào)內(nèi)的類型名。??操作數(shù)的存儲(chǔ)大小由操作數(shù)的類型決定?!???
二、sizeof的使用方法??
1、用于數(shù)據(jù)類型 ???
sizeof使用形式: sizeof(type)
數(shù)據(jù)類型必須用括號(hào)括住: sizeof(int)
2、用于變量 ???
sizeof使用形式: sizeof(var_name) 或 sizeof var_name ???
變量名可以不用括號(hào)括住.如sizeof (var_name),sizeof var_name等都是正確形式????帶括號(hào)的用法更普遍,大多數(shù)程序員采用這種形式?!???
注意:sizeof操作符不能用于函數(shù)類型,不完全類型或位字段。??????????不完全類型指具有未知存儲(chǔ)大小的數(shù)據(jù)類型,??????????如未知存儲(chǔ)大小的數(shù)組類型、未知內(nèi)容的結(jié)構(gòu)或聯(lián)合類型、void類型等?!???
例如: sizeof(max)????--若此時(shí)變量max定義為int max();?????sizeof(char_v) ??--若此時(shí)char_v定義為char char_v[MAX]且MAX未知,?????sizeof(void)???????????以上都是不正確形式?!???
三、sizeof的結(jié)果(以下結(jié)果都是在Linux v2.6 gcc v4獲取)
sizeof操作符的結(jié)果類型是size_t??它在頭文件中定義為: typedef unsigned int size_t;???????該類型保證能容納實(shí)現(xiàn)所建立的最大對(duì)象的字節(jié)大小.
1、ANSI C正式規(guī)定字符類型為1字節(jié)。 ???
????sizeof(char)?????= 1;????sizeof(unsigned char) = 1;????sizeof(signed char)? = 1;
2、其他類型在ANSI C中沒有具體規(guī)定,大小依賴于實(shí)現(xiàn)。????sizeof(int)???????= 4;????sizeof(unsigned int)?? = 4;????sizeof(short int)????= 2;????sizeof(unsigned short)? = 2;????sizeof(long int)???? = 4;????sizeof(unsigned long)??= 4;????sizeof(float)??????= 4;????sizeof(double)????? = 8;????sizeof(long double)???= 12;
3、當(dāng)操作數(shù)是指針時(shí),sizeof依賴于編譯器。????????Microsoft C/C++7.0中,near類指針字節(jié)數(shù)為2,far、huge類指針字節(jié)數(shù)為4。????????一般Unix/Linux的指針字節(jié)數(shù)為4。 ???????????例如: char *p;??????//Linux中?????????? ? ? ?sizeof(p) = 4;
4、當(dāng)操作數(shù)具有數(shù)組類型時(shí),其結(jié)果是數(shù)組的總字節(jié)數(shù)。???? ? ? ?例如: char a[5];?????????? ? ? ? ?int??b[5];?????????? ? ? ? ?sizeof(a)?= 5;?????????? ? ? ? ?sizeof(b) = 20;???????5、當(dāng)操作數(shù)是具體的字符串或者數(shù)值時(shí),會(huì)根據(jù)具體的類型進(jìn)行相應(yīng)轉(zhuǎn)化。????? ? ?例如:? sizeof(8)????= 4;?? //自動(dòng)轉(zhuǎn)化為int類型??????????????????sizeof(8.8)??= 8;?? //自動(dòng)轉(zhuǎn)化為double類型,注意,不是float類型?????????? ? ? ? ?sizeof("ab") = 3??? //自動(dòng)轉(zhuǎn)化為數(shù)組類型,?????????????????????????????????????????????//長度是4,不是3,因?yàn)榧由狭俗詈蟮?n'符?????????????????????????????????????????????//有資料說,會(huì)自動(dòng)轉(zhuǎn)化為指針類型(Linux為4)?????????????????????????????????????????????//可能和操作系統(tǒng)與編譯器有關(guān)系?????????
6、當(dāng)操作數(shù)是聯(lián)合類型時(shí),sizeof是其最大字節(jié)成員的字節(jié)數(shù)。??????? ? ?當(dāng)操作數(shù)是結(jié)構(gòu)類型時(shí),sizeof是其成員類型的總字節(jié)數(shù),包括補(bǔ)充字節(jié)在內(nèi)?!???????????還是讓我們拿例子來說話:
????union??u{?????????????//對(duì)union來說 ??????????char?c; ??????????double?d; ????}u; ????sizeof(u)?=?max(sizeof(c),sizeof(d))?=?sizeof(1,8)?=?8; struct?a{?????????????//對(duì)struct來說 ??????????char b; ??????????double x; ????}a;
在Linux上: sizeof(a) = 12;????而一般sizeof(char) + sizeof(double) = 9;?
這是因?yàn)榫幾g器在考慮對(duì)齊問題時(shí),在結(jié)構(gòu)中插入空位以控制各成員對(duì)象的地址對(duì)齊。????但如果全對(duì)齊的話,sizeof(a) = 16, 這是因?yàn)閎被放到偏移量為0的地址,占1個(gè)字節(jié);????在存放x時(shí),double類型長度為8,需要放到能被8整除的偏移量上,這時(shí)候需要補(bǔ)7個(gè)空字節(jié),????達(dá)到8個(gè),這時(shí)候偏移量為8,放上x后長度為16。????在此例中,所有的結(jié)構(gòu)成員都要放在被4整除的地址(Linux的存放方式),這里補(bǔ)3個(gè)字節(jié),所以為12。
7、當(dāng)操作數(shù)是函數(shù)中的數(shù)組形參或函數(shù)類型的形參:???????sizeof給出其指針的大小,Linux中值為4。
四、sizeof與其他操作符的關(guān)系??
sizeof的優(yōu)先級(jí)為2級(jí),比/、%等3級(jí)運(yùn)算符優(yōu)先級(jí)高。????它可以與其他操作符一起組成表達(dá)式:????例如: int i = 10;??????????i * sizeof(int);
五、sizeof的主要用途??
1、主要用途是與存儲(chǔ)分配和I/O系統(tǒng)那樣的例程進(jìn)行通信。???? ? ? ? 例如: void *malloc(size_t size);
????? size_t fread(void *ptr, size_t size, size_t nmemb, FILE * stream); ???
2、另一個(gè)的主要用途是計(jì)算數(shù)組中元素的個(gè)數(shù)。???? ? ? ?例如: void *memset(void *s, int c, sizeof(s));