天天看點

sizeof()詳解

一、sizeof的概念  

  sizeof是C語言的一種單目操作符,如C語言的其他操作符++、--等, 它并不是函數。 sizeof操作符以位元組形式給出了其操作數的存儲大小。  操作數可以是一個表達式或括在括号内的類型名。  操作數的存儲大小由操作數的類型決定。      

二、sizeof的使用方法  

1、用于資料類型    

  sizeof使用形式: sizeof(type)

2、用于變量    

  sizeof使用形式: sizeof(var_name) 或 sizeof var_name    

  變量名可以不用括号包覆.如sizeof (var_name),sizeof var_name等都是正确形式     帶括号的用法更普遍,大多數程式員采用這種形式。    

  注意:sizeof操作符不能用于函數類型,不完全類型或位字段。           不完全類型指具有未知存儲大小的資料類型, 如未知存儲大小的數組類型、未知内容的結構或聯合類型、void類型等。         例如: sizeof(max)        --若此時變量max定義為int max();           sizeof(char_v)    --若此時char_v定義為char char_v[MAX]且MAX未知,           sizeof(void)                 以上都是不正确形式。    

三、sizeof的結果(以下結果都是在Linux v2.6 gcc v4擷取)

  sizeof操作符的結果類型是size_t,  它在頭檔案中定義為: typedef unsigned int size_t; 該類型保證能容納實作所建立的最大對象的位元組大小.。

1、ANSI C正式規定字元類型為1位元組。    

    sizeof(char)          = 1;     sizeof(unsigned char) = 1;     sizeof(signed char)   = 1;

  

2、其他類型在ANSI C中沒有具體規定,大小依賴于實作。     

    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、當操作數是指針時,sizeof依賴于編譯器。

    Microsoft C/C++7.0中,near類指針位元組數為2,far、huge類指針位元組數為4。     一般Unix/Linux的指針位元組數為4。         例如: char *p;      //Linux中           sizeof(p) = 4;

4、當操作數具有數組類型時,其結果是數組的總位元組數。       例如: char a[5];              int  b[5];      char c[]={"12345" } ;               sizeof(a)  = 5;           sizeof(b) = 20;  sizeof(c)=6;    //字元串指派後面加上’\n‘作為結束符,sizeof()會統計,但strlen(c)=5,不統計'\n'。     5、當操作數是具體的字元串或者數值時,會根據具體的類型進行相應轉化。       例如: sizeof(8)    = 4;  //自動轉化為int類型           sizeof(8.8)  = 8;  //自動轉化為double類型,注意,不是float類型           sizeof("ab") = 3   //自動轉化為數組類型,                              //長度是4,不是3,因為加上了最後的'\n'符                              //有資料說,會自動轉化為指針類型(Linux為4)                              //可能和作業系統與編譯器有關系          

6、當操作數是聯合類型時,sizeof是其最大位元組成員的位元組數。        當操作數是結構類型時,sizeof是其成員類型的總位元組數,包括補充位元組在内。              還是讓我們拿例子來說話:     union  u{             //對union來說           char c;           double d;     }u;     sizeof(u) = max(sizeof(c),sizeof(d)) = sizeof(1,8) = 8;

  struct a{             //對struct來說           char b;            double x;     }a;   

  在Linux上: sizeof(a) = 12;(其他編譯器16)     而一般sizeof(char) + sizeof(double) = 9; 

  這是因為編譯器在考慮對齊問題時,在結構中插入空位以控制各成員對象的位址對齊。     但如果全對齊的話,sizeof(a) = 16, 這是因為b被放到偏移量為0的位址,占1個位元組;     在存放x時,double類型長度為8,需要放到能被8整除的偏移量上,這時候需要補7個空位元組,     達到8個,這時候偏移量為8,放上x後長度為16。     在此例中,所有的結構成員都要放在被4整除的位址(Linux的存放方式),這裡補3個位元組,是以為12。

7、當操作數是函數中的數組形參或函數類型的形參:

    sizeof給出其指針的大小,Linux中值為4。

四、總結: sizeof()在C中使用很廣泛,是易錯易忽視的知識點,需要多加注意.

摘自:http://blog.sina.com.cn/s/blog_5da08c340100bmwu.html點選打開連結