亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

C語(yǔ)言

C語(yǔ)言中sizeof的用法

時(shí)間:2024-09-09 15:20:18 C語(yǔ)言 我要投稿
  • 相關(guān)推薦

C語(yǔ)言中sizeof的用法

  C語(yǔ)言的應(yīng)用范圍廣泛,具備很強(qiáng)的數(shù)據(jù)處理能力,不僅僅是在軟件開發(fā)上,而且各類科研都需要用到C語(yǔ)言,適于編寫系統(tǒng)軟件,三維,二維圖形和動(dòng)畫,具體應(yīng)用比如單片機(jī)以及嵌入式系統(tǒng)開發(fā)。以下是小編為大家搜索整理的C語(yǔ)言中sizeof的用法,希望能給大家?guī)?lái)幫助!

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

  這是一個(gè)依賴于編譯系統(tǒng)的值,一般定義為typedef unsigned int size_t;編譯器林林總總,但作為一個(gè)規(guī)范,都會(huì)保證char、signed

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

  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、語(yǔ)法:

  sizeof有三種語(yǔ)法形式,如下:

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

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

  3) sizeof object; // sizeof 對(duì)象;

  所以一下三種sizeof的使用都是對(duì)的

  復(fù)制代碼 代碼如下:

  #include

  main()

  {

  int b;

  printf("%dn",sizeof b);

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

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

  }

  4、基本數(shù)據(jù)類型的sizeof

  這里的基本數(shù)據(jù)類型指short、int、long、float、double這樣的簡(jiǎn)單內(nèi)置數(shù)據(jù)類型,由于它們都是和系

  統(tǒng)相關(guān)的,所以在不同的系統(tǒng)下取值可能不同,這務(wù)必引起我們的注意,盡量不要在

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

  5、指針變量的sizeof

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

  字節(jié)為單位),可以預(yù)計(jì),在將來(lái)的64位系統(tǒng)中指針變量的sizeof結(jié)果為8。

  指針變量的sizeof值與指針?biāo)傅膶?duì)象沒有任何關(guān)系,正是由于所有的指針變量所占內(nèi)存大小相等,所以

  MFC消息處理函數(shù)使用兩個(gè)參數(shù)WPARAM、LPARAM就能傳遞各種復(fù)雜的消息結(jié)構(gòu)(使用

  指向結(jié)構(gòu)體的指針)。

  6、數(shù)組的sizeof

  數(shù)組的sizeof值等于數(shù)組所占用的內(nèi)存字節(jié)數(shù),如:

  char a1[] = "abc";

  int a2[3];

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

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

  sizeof當(dāng)作了求數(shù)組元素的個(gè)數(shù)是不對(duì)的,求數(shù)組元素的個(gè)數(shù)有下面兩種寫法:int c1 = sizeof( a1 )

  / sizeof( char ); // 總長(zhǎng)度/單個(gè)元素的長(zhǎng)度

  int c2 = sizeof( a1 ) / sizeof( a1[0] ); // 總長(zhǎng)度/第一個(gè)元素的長(zhǎng)度。注意數(shù)組名做函數(shù)參數(shù)傳遞

  時(shí)退化為指針。

  7、結(jié)構(gòu)體的sizeof

  struct S1

  {

  char c;

  int i;

  };

  sizeof的結(jié)果等于對(duì)象或者類型所占的內(nèi)存字節(jié)數(shù),好吧,那就讓我們來(lái)看看S1的內(nèi)存分配情況:S1 s1

  = { 'a', 0xFFFFFFFF };s1的地址為0x0012FF78,其數(shù)據(jù)內(nèi)容如下:

  0012FF78: 61 CC CC CC FF FF FF FF中間夾雜了3個(gè)字節(jié)的CC看看MSDN上的說(shuō)明:When applied to a

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

  include padding bytes ed for alignment.

  這就是字節(jié)對(duì)齊!為什么需要字節(jié)對(duì)齊計(jì)算機(jī)組成原理教導(dǎo)我們這樣有助于加快計(jì)算機(jī)的取數(shù)速度,否則

  就得多花指令周期了。為此,編譯器默認(rèn)會(huì)對(duì)結(jié)構(gòu)體進(jìn)行處理(實(shí)際上其它地方的數(shù)

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

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

  需要加入填充字節(jié),所以整個(gè)結(jié)構(gòu)體的sizeof值就增長(zhǎng)了。

  1、sizeof是運(yùn)算符,跟加減乘除的性質(zhì)其實(shí)是一樣的,在編譯的時(shí)候進(jìn)行執(zhí)行,而不是在運(yùn)行時(shí)才執(zhí)行。

  那么如果編程中驗(yàn)證這一點(diǎn)呢?

  復(fù)制代碼 代碼如下:

  #include

  using namespace std;

  int main()

  {

  int i=1;

  cout<

  sizeof(++i);

  cout<

  return 1;

  }

  輸入結(jié)果為 1

  1

  sizeof 中的++i 的副作用并沒有顯示出來(lái),原因只可能有一個(gè),在編譯的時(shí)候sizeof執(zhí)行以后將++i 處理了,++i 的副作用因此被消除了。如果sizeof 是在運(yùn)行時(shí)進(jìn)行的話,則肯定要注意++i 。實(shí)際上sizeof的實(shí)現(xiàn)應(yīng)該是用宏來(lái)做的,宏在編譯時(shí)進(jìn)行執(zhí)行。具體實(shí)現(xiàn)可以參考下面。

  2、sizeof('a')在C語(yǔ)言中的結(jié)果是4,在C++中結(jié)果是1,看過(guò)某篇文章說(shuō)C中sizeof側(cè)重于“數(shù)”,而C++中sizeof更側(cè)重于“字符”。

  3、文章中講了兩個(gè)用宏實(shí)現(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))

  先舉兩個(gè)小例子說(shuō)明兩個(gè)宏的應(yīng)用,對(duì)于第一個(gè)如 _sizeof(int); 的結(jié)果就是4;對(duì)于第二個(gè)先聲明一個(gè)大小為4的數(shù)組int a[4];那么array_sizeof(a)結(jié)果為16.

  對(duì)于非數(shù)組的宏定義,先是將0轉(zhuǎn)換為T*類型的指針?biāo)赶虻牡刂罚ù藭r(shí)地址為0)。然后對(duì)T類型的地址加1,相當(dāng)于加上了T類型的大小(即得到了非數(shù)組T的大。G懊娴膕ize_t只是將地址轉(zhuǎn)化為int型的整數(shù)返回。

  一個(gè)簡(jiǎn)單的例子:int* p; p=p+1; ——p是一個(gè)int*類型的指針, p+1在地址空間上相當(dāng)于加上了4個(gè)字節(jié)。

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

  拓展閱讀:C語(yǔ)言變量理解

  一、變量的概念

  程序設(shè)計(jì)就是讓計(jì)算機(jī)按照一定的指令來(lái)進(jìn)行工作,可以說(shuō)數(shù)據(jù)的處理是程序設(shè)計(jì)的主要任務(wù)。那么數(shù)據(jù)是怎么加入到計(jì)算機(jī)的內(nèi)存中呢?計(jì)算機(jī)最初的功能就是能夠存儲(chǔ)數(shù)據(jù)并處理數(shù)據(jù)的機(jī)器。那么數(shù)據(jù)是怎么加入到計(jì)算機(jī)的內(nèi)存中呢?在學(xué)習(xí)程序設(shè)計(jì)之前,很多學(xué)生對(duì)計(jì)算機(jī)的硬件設(shè)施都大概已經(jīng)很熟悉了。計(jì)算機(jī)的硬件設(shè)施中有一個(gè)區(qū)域是用來(lái)存儲(chǔ)數(shù)據(jù)的,計(jì)算機(jī)在工作的過(guò)程中會(huì)頻繁的從這個(gè)區(qū)域讀入和讀出數(shù)據(jù)。要想讓計(jì)算機(jī)按照某些指令(程序)自動(dòng)工作,首先必須把數(shù)據(jù)存儲(chǔ)到計(jì)算機(jī)的存儲(chǔ)空間中。在某種計(jì)算機(jī)語(yǔ)言中實(shí)現(xiàn)這種數(shù)據(jù)存儲(chǔ)功能的就是變量。變量就是計(jì)算機(jī)內(nèi)存中的某一個(gè)存儲(chǔ)單元。

  二、變量的定義

  C語(yǔ)言中變量在使用之前必須先對(duì)其進(jìn)行定義,變量的定義的一般形式如下:【存儲(chǔ)類別】數(shù)據(jù)類型變量名;其中存儲(chǔ)類別是可以省略的。

  1、存儲(chǔ)類別計(jì)算機(jī)的內(nèi)存一般分為三個(gè)部分:1)程序區(qū);2)靜態(tài)存儲(chǔ)區(qū);3)動(dòng)態(tài)存儲(chǔ)區(qū);為了高效的發(fā)揮計(jì)算機(jī)的功能,不同類型的變量存放在不同的內(nèi)存區(qū)域。變量的存儲(chǔ)類別決定了變量中的數(shù)據(jù)在計(jì)算機(jī)內(nèi)存中的存儲(chǔ)位置。C語(yǔ)言中局部變量存放在動(dòng)態(tài)存儲(chǔ)區(qū),全局變量或者靜態(tài)變量存放在靜態(tài)存儲(chǔ)區(qū)。

  2、數(shù)據(jù)類型在用程序處理問題之前,首先必須確定用何種方式描述問題中所涉及到的數(shù)據(jù)。這個(gè)問題在C語(yǔ)言中是由數(shù)據(jù)類型來(lái)決定的。變量的本質(zhì)表現(xiàn)為在計(jì)算機(jī)中的存在時(shí)間和存儲(chǔ)空間。變量的數(shù)據(jù)類型是用來(lái)決定變量在計(jì)算機(jī)中占用內(nèi)存空間的大小。比如:整型數(shù)據(jù)在TC編譯系統(tǒng)中占用兩個(gè)字節(jié)的存儲(chǔ)空間。C語(yǔ)言變量的類型不僅確定了數(shù)據(jù)在計(jì)算機(jī)內(nèi)存中的存儲(chǔ)區(qū)域的大小,同時(shí)確定了該數(shù)據(jù)能夠參與的各種運(yùn)算。任何一個(gè)C語(yǔ)言的變量必須有確定的數(shù)據(jù)類型,不管這個(gè)變量如何變化,變量的值都必須符合該變量數(shù)據(jù)類型的規(guī)定。

  3、變量的名字通過(guò)以上介紹我們知道C語(yǔ)言中的變量就是計(jì)算機(jī)的某個(gè)存儲(chǔ)單元,假設(shè)你給某個(gè)變量賦予了一個(gè)數(shù)值,對(duì)變量的處理其實(shí)就是對(duì)這個(gè)數(shù)據(jù)的處理。那么計(jì)算機(jī)是如何快速準(zhǔn)確的找到這個(gè)數(shù)據(jù)呢?計(jì)算機(jī)的內(nèi)存是以字節(jié)為單位進(jìn)行劃分的。每個(gè)存儲(chǔ)單元都有自己的地址編號(hào),就向賓館中房間的房間號(hào)一樣。計(jì)算機(jī)就是通過(guò)地址來(lái)準(zhǔn)確的確定數(shù)據(jù)的存儲(chǔ)位置。但是對(duì)于程序員特別是非專業(yè)計(jì)算機(jī)人士,如果用計(jì)算機(jī)內(nèi)存地址記錄數(shù)據(jù)是非常難操作的。

  為了更好的掌控變量,C語(yǔ)言規(guī)定可以給每個(gè)變量其一個(gè)容易識(shí)別的名字。這個(gè)名字的命名規(guī)則遵循C語(yǔ)言的標(biāo)識(shí)符命名規(guī)則。C語(yǔ)言的變量名的命名在遵循C語(yǔ)言標(biāo)識(shí)符規(guī)則的前提下,原則上可以是任意長(zhǎng)度字符的組合。但是目前很多的C語(yǔ)言編譯系統(tǒng)只能識(shí)別前31個(gè)字符,如果兩個(gè)變量的前31個(gè)字符相同,則編譯系統(tǒng)會(huì)認(rèn)為這兩個(gè)變量時(shí)同一個(gè)變量。為了避免這種混淆的出現(xiàn)最好避免使用多余31個(gè)字符的變量名。變量的理解變量就是計(jì)算機(jī)中的某個(gè)存儲(chǔ)單元。定義某個(gè)變量本質(zhì)上就是向計(jì)算機(jī)申請(qǐng)一些存儲(chǔ)區(qū)域。這個(gè)存儲(chǔ)區(qū)域的大小由變量的數(shù)據(jù)類型決定,這個(gè)存儲(chǔ)區(qū)域的位置有變量的存儲(chǔ)類類別決定。給變量賦予某個(gè)數(shù)值,其實(shí)就是向該變量對(duì)應(yīng)的存儲(chǔ)單元讀入數(shù)據(jù),對(duì)變量的處理就是對(duì)這個(gè)存儲(chǔ)單元中的數(shù)據(jù)的處理。并且這個(gè)存儲(chǔ)單元中的數(shù)據(jù)在程序的運(yùn)行期間是可以發(fā)生變化的。

【C語(yǔ)言中sizeof的用法】相關(guān)文章:

C語(yǔ)言中Sizeof與Strlen的區(qū)別與聯(lián)系09-02

C語(yǔ)言中strpbr()函數(shù)的用法07-25

c語(yǔ)言中time函數(shù)的用法08-27

C語(yǔ)言中volatile的含義08-14

C 語(yǔ)言中宏的使用08-02

C語(yǔ)言中的鏈接編寫05-26

html語(yǔ)言中URL的用法06-20

php語(yǔ)言中session用法07-02

C語(yǔ)言中指針的概念03-16

c語(yǔ)言中邏輯或怎么用07-05