<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            C語言

            對C語言中的sizeof的介紹分析

            時間:2025-05-26 01:12:28 C語言 我要投稿
            • 相關推薦

            對C語言中的sizeof的介紹分析

              引導語::sizeof是C語言中判斷數據類型或者表達式長度符,以下是百分網小編分享給大家的對C語言中的sizeof的介紹分析,歡迎閱讀!

              1.定義

              sizeof是C/C++中的一個操作符(operator),作用就是返回一個對象或者類型所占的內存字節數。返回值類型為size_t,在頭文件stddef.h中定義。

              這是一個依賴于編譯系統的值,一般定義為typedef unsigned int size_t;編譯器林林總總,但作為一個規范,都會保證char、signed

              char和unsigned char的sizeof值為1,畢竟char是編程能用的最小數據類型。

              MSDN上的解釋為:

              The sizeof keyword gives the amount of storage, in bytes, associated with avariable or a

              type (including aggregate types). This keyword returns a value of type

              size_t.

              2. 語法:

              sizeof有三種語法形式,如下:

              1) sizeof( object ); // sizeof( 對象 );

              2) sizeof( type_name ); // sizeof( 類型 );

              3) sizeof object; // sizeof 對象;

              所以一下三種sizeof的使用都是對的

              復制代碼 代碼如下:

              #include

              main()

              {

              int b;

              printf("%dn",sizeof b);

              printf("%dn",sizeof(b));

              printf("%dn",sizeof(int));

              }

              3. 基本數據類型的sizeof

              這里的基本數據類型指short、int、long、float、double這樣的簡單內置數據類型,由于它們都是和系

              統相關的,所以在不同的系統下取值可能不同,這務必引起我們的注意,盡量不要在

              這方面給自己程序的移植造成麻煩。一般的,在32位編譯環境中,sizeof(int)的取值為4。

              4. 指針變量的sizeof

              等于計算機內部地址總線的寬度。所以在32位計算機中,一個指針變量的返回值必定是4(注意結果是以

              字節為單位),可以預計,在將來的64位系統中指針變量的sizeof結果為8。

              指針變量的sizeof值與指針所指的對象沒有任何關系,正是由于所有的指針變量所占內存大小相等,所以

              MFC消息處理函數使用兩個參數WPARAM、LPARAM就能傳遞各種復雜的消息結構(使用

              指向結構體的指針)。

              5. 數組的sizeof

              數組的sizeof值等于數組所占用的內存字節數,如:

              char a1[] = "abc";

              int a2[3];

              sizeof( a1 ); // 結果為4,字符 末尾還存在一個NULL終止符

              sizeof( a2 ); // 結果為3*4=12(依賴于int)

              sizeof當作了求數組元素的個數是不對的,求數組元素的個數有下面兩種寫法:int c1 = sizeof( a1 )

              / sizeof( char ); // 總長度/單個元素的長度

              int c2 = sizeof( a1 ) / sizeof( a1[0] ); // 總長度/第一個元素的長度.注意數組名做函數參數傳遞

              時退化為指針。

              6. 結構體的sizeof

              struct S1

              {

              char c;

              int i;

              };

              sizeof的結果等于對象或者類型所占的內存字節數,好吧,那就讓我們來看看S1的內存分配情況:S1 s1

              = { 'a', 0xFFFFFFFF };s1的地址為0x0012FF78,其數據內容如下:

              0012FF78: 61 CC CC CC FF FF FF FF中間夾雜了3個字節的CC看看MSDN上的說明:When applied to a

              structure type or variable, sizeof returns the actual size, which may

              include padding bytes inserted for alignment.

              這就是字節對齊!為什么需要字節對齊計算機組成原理教導我們這樣有助于加快計算機的取數速度,否則

              就得多花指令周期了。為此,編譯器默認會對結構體進行處理(實際上其它地方的數

              據變量也是如此),讓寬度為2的基本數據類型(short等)都位于能被2整除的地址上,讓寬度為4的基本

              數據類型(int等)都位于能被4整除的地址上,以此類推。這樣,兩個數中間就可能

              需要加入填充字節,所以整個結構體的sizeof值就增長了。

              1.sizeof是運算符,跟加減乘除的性質其實是一樣的,在編譯的時候進行執行,而不是在運行時才執行。

              那么如果編程中驗證這一點呢?

              復制代碼 代碼如下:

              #include

              using namespace std;

              int main()

              {

              int i=1;

              cout<

              sizeof(++i);

              cout<

              return 1;

              }

              輸入結果為 1

              1

              sizeof 中的++i 的副作用并沒有顯示出來,原因只可能有一個,在編譯的時候sizeof執行以后將++i 處理了,++i 的副作用因此被消除了。如果sizeof 是在運行時進行的話,則肯定要注意++i 。實際上sizeof的實現應該是用宏來做的,宏在編譯時進行執行。具體實現可以參考下面。

              2.sizeof('a')在C語言中的結果是4,在C++中結果是1,看過某篇文章說C中sizeof側重于“數”,而C++中sizeof更側重于“字符”。

              3.文章中講了兩個用宏實現sizeof的經典應用

              復制代碼 代碼如下:

              //適用于非數組

              #define _sizeof(T) ((size_t)((T*)0 + 1))

              //適用于數組

              #define array_sizeof(T) ((size_t)(&T+1)-(size_t)(&T))

              先舉兩個小例子說明兩個宏的應用,對于第一個如 _sizeof(int); 的結果就是4;對于第二個先聲明一個大小為4的數組int a[4];那么array_sizeof(a)結果為16.

              對于非數組的宏定義,先是將0轉換為T*類型的指針所指向的地址(此時地址為0)。然后對T類型的地址加1,相當于加上了T類型的大小(即得到了非數組T的大小)。前面的size_t只是將地址轉化為int型的整數返回。

              一個簡單的例子:int* p; p=p+1; --------p是一個int*類型的指針, p+1在地址空間上相當于加上了4個字節。

              對 于數組的宏定義,類似于非數組的宏定義,為了方便理解,這里可以把數組T看成一個用戶自定義的類型,&T表示數組類型的指針,對于數組類型指針加 1相當于在地址上加上了該數組大小。由于是用戶自定義的類型所以不能強制將0轉化為數組類型的地址,只能用加1后的地址減去之前的地址,得到的差值就是數 組本身所占的字節大小。

            【對C語言中的sizeof的介紹分析】相關文章:

            C語言中sizeof的用法09-09

            C語言中Sizeof與Strlen的區別與聯系09-02

            C語言的sizeof與strlen10-14

            C語言中strstr()函數的使用分析08-03

            C語言中volatile關鍵字分析07-26

            C語言中位段的詳細介紹06-08

            C語言中指針的用法介紹10-27

            C語言中的整數06-16

            C語言中的字符07-18

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院