欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解C++ sizeof(上)

 更新時(shí)間:2020年08月15日 09:59:47   作者:Dabelv  
這篇文章主要介紹了C++ sizeof的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下

sizeof是C/C++中的一個(gè)操作符(operator),其作用是返回一個(gè)對(duì)象或者類型所占的內(nèi)存字節(jié)數(shù),使用頻繁,有必須對(duì)其有個(gè)全面的了解。

1.sizeof的基本語法

sizeof有三種語法形式。

(1)sizeof(object); //sizeof(對(duì)象);
(2)sizeof(type_name); //sizeof(類型);
(3)sizeof object; //sizeof對(duì)象;

第三種語法結(jié)構(gòu)雖然簡約,但并不常見,為簡單統(tǒng)一,建議使用第一和第二種寫法。

int i;
sizeof( i ); // ok
sizeof i; // ok
sizeof( int ); // ok
sizeof int; // error

2.sizeof計(jì)算基本類型與表示式

sizeof計(jì)算對(duì)象的大小實(shí)際上是轉(zhuǎn)換成對(duì)象類型進(jìn)行計(jì)算,也就是說,同種類型的不同對(duì)象其sizeof值都是一致的。這里,對(duì)象可以進(jìn)一步延伸至表達(dá)式,即sizeof可以對(duì)一個(gè)表達(dá)式求值,編譯器根據(jù)表達(dá)式的最終結(jié)果類型來確定大小,sizeof是編譯時(shí)進(jìn)行運(yùn)算,與運(yùn)行時(shí)無關(guān),不會(huì)對(duì)表達(dá)式進(jìn)行計(jì)算??疾烊缦麓a:

#include <iostream>
using namespace std;
int main(int argc,char* argv[])
{
cout<<"sizeof(char)="<<sizeof(char)<<endl;
cout<<"sizeof(short)="<<sizeof(short int)<<endl;
cout<<"sizeof(int)="<<sizeof(int)<<endl;
cout<<"sizeof(long)="<<sizeof(long int)<<endl;
cout<<"sizeof(long long)="<<sizeof(long int int)<<endl;
cout<<"sizeof(float)="<<sizeof(float)<<endl;
cout<<"sizeof(double)="<<sizeof(double)<<endl;
int i=8;
cout<<"i="<<i<<endl;
cout<<"sizeof(i)="<<sizeof(i)<<endl;
cout<<"sizeof(i)="<<sizeof(i=5)<<endl;
cout<<"i="<<i<<endl;
}

在64bits的Windows下運(yùn)行結(jié)果如下:

sizeof(char)=1
sizeof(short)=2
sizeof(int)=4
sizeof(long)=4
sizeof(long long)=4
sizeof(float)=4
sizeof(double)=8
i=8
sizeof(i)=4
sizeof(i)=4
i=8

觀察以上程序需要注意兩點(diǎn)。

(1)i的值并未發(fā)生改變,表明sizeof括號(hào)內(nèi)的表達(dá)式并沒有執(zhí)行,sizeof在編譯時(shí)求其表達(dá)式的運(yùn)算結(jié)果的類型,sizeof運(yùn)算與運(yùn)行時(shí)無關(guān)。sizeof(i)等價(jià)于sizeof(int),sizeof(i=5)等價(jià)于sizeof(int),也就是說在可執(zhí)行代碼中,并不包含i=5這個(gè)表達(dá)式,它早在編譯階段就被處理了。
(2)long int是否占8字節(jié),與編譯器的實(shí)現(xiàn)有關(guān),Visual C++在VS2012中使用的編譯器是cl.exe,在64bits的Windows下仍然將long編譯為4字節(jié),要想使用8字節(jié)長整型,保險(xiǎn)起見,使用long long型。

3.sizeof計(jì)算指針變量

指針是C/C++的靈魂,它記錄了一個(gè)對(duì)象的地址。指針變量的位寬等于機(jī)器字長,機(jī)器字長由CPU寄存器位數(shù)決定。在32位系統(tǒng)中,一個(gè)指針變量的返回值為4字節(jié),64位系統(tǒng)中指針變量的sizeof結(jié)果為8字節(jié)。

char* pc = "abc";
int* pi=new int[10];
string* ps;
char** ppc = &pc;
void (*pf)(); // 函數(shù)指針
char testfunc()
{
return ‘k';
}
sizeof( pc ); // 結(jié)果為4
sizeof( pi ); // 結(jié)果為4
sizeof( ps ); // 結(jié)果為4
sizeof( ppc ); // 結(jié)果為4
sizeof( pf ); // 結(jié)果為4
sizeof( &testfunc ); // 結(jié)果為4
sizeof( testfunc ()); // 結(jié)果為1
sizeof(*( testfunc) ()); // 結(jié)果為1

考察以上代碼,得出如下結(jié)論:

(1)指針變量的sizeof值與指針?biāo)傅膶?duì)象類型沒有任何關(guān)系,與指針申請(qǐng)多少空間沒有關(guān)系,所有的指針變量所占內(nèi)存大小均相等。那為什么在本機(jī)64bits系統(tǒng)下,指針變量大小仍然是4個(gè)字節(jié),因?yàn)槭褂?2位編譯器編譯得到程序是32位,故指針大小是4字節(jié),可自行修改編譯器版本,不再贅述。

(2)&testfunc代表一個(gè)函數(shù)指針,指針大小是4,所以sizeof(&testfunc)==4。testfunc()代表一次函數(shù)調(diào)用,返回值類型是char,所以sizeof(testfunc())==sizeof(char)==1。testfunc名本身就是一個(gè)函數(shù)指針,所以(*testfunc)()也是一次函數(shù)調(diào)用,sizeof((*testfunc)())==sizeof(char)==1

4.sizeof計(jì)算數(shù)組

當(dāng)sizeof作用于數(shù)組時(shí),求取的是數(shù)組所有元素所占用的大小。參考如下代碼:

int A[3][5];
char c[]="123456";
double*(*d)[3][6];

cout<<sizeof(A)<<endl; //輸出60
cout<<sizeof(A[4])<<endl; //輸出20
cout<<sizeof(A[0][0])<<endl;//輸出4
cout<<sizeof(c)<<endl; //輸出7
cout<<sizeof(d)<<endl; //輸出4
cout<<sizeof(*d)<<endl; //輸出72
cout<<sizeof(**d)<<endl; //輸出24
cout<<sizeof(***d)<<endl; //輸出4
cout<<sizeof(****d)<<endl; //輸出8

考察以上代碼,得出如下結(jié)論:
(1)A的數(shù)據(jù)類型是int[3][5],A[4]的數(shù)據(jù)類型是int[5]A[0][0]數(shù)據(jù)類型是int。所以

sizeof(A)==sizeof(int[3][5])==3*5*sizeof(int)==60
sizeof(A[4])==sizeof(int[5])=5*sizeof(int)==20
sizeof(A[0][0])==sizeof(int)==4

盡管A[4]的下標(biāo)越界,但不會(huì)造成運(yùn)行時(shí)錯(cuò)誤,因?yàn)閟izeof運(yùn)算只關(guān)心數(shù)據(jù)類型,在編譯階段就已經(jīng)完成。

(2)由于字符串以空字符'\0'結(jié)尾,所以c的數(shù)據(jù)類型是char[7],所以sizeof(c)=sizeof(char[7])==7。

(3)d是一個(gè)指針,不管它指向的對(duì)象是什么數(shù)據(jù)類型,自身大小永遠(yuǎn)是4,所以sizeof(d)==4。sizeof(*d)的數(shù)據(jù)類型是double*[3][6],所以

sizeof(*d)==sizeof(double*[3][6])==3*6*sizeof(double*)==18*4==72

同理,可以推算出

sizeof(**d)==sizeof(double*[6])==6*sizeof(double*)==24
sizeof(***d)==sizeof(double*)==4
sizeof(****d)=sizeof(double)==8

當(dāng)數(shù)組作為函數(shù)形參時(shí),下面的i和j的值應(yīng)該是多少呢?

void foo1(char a1[3])
{
int i = sizeof( a1 ); // i == ?
}
void foo2(char a2[])
{
int j = sizeof( a2); // j == ?
}

也許當(dāng)你試圖回答j的值時(shí)已經(jīng)意識(shí)到i答錯(cuò)了,是的,i!=3。這里函數(shù)參數(shù)a1已不再是數(shù)組類型,而是蛻變成指針,相當(dāng)于char* a1,為什么?仔細(xì)想想就不難明白,我們調(diào)用函數(shù)foo1時(shí),程序會(huì)在棧上分配一個(gè)大小為3的數(shù)組嗎?不會(huì)!數(shù)組是“傳址”的,調(diào)用者只需將實(shí)參的地址傳遞過去,所以a1自然為指針類型(char*),i的值也就為4,同樣j也是4。

以上就是詳解C++ sizeof(上)的詳細(xì)內(nèi)容,更多關(guān)于C++ sizeof的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Windows配置Qt環(huán)境變量的全指南

    Windows配置Qt環(huán)境變量的全指南

    Qt是一個(gè)跨平臺(tái)C++開發(fā)框架,包含GUI、網(wǎng)絡(luò)、SQL、多媒體等模塊,安裝后自帶豐富工具鏈,若未正確配置環(huán)境變量會(huì)導(dǎo)致一系列問題,因此建議根據(jù)實(shí)際開發(fā)場(chǎng)景,合理設(shè)置局部或臨時(shí)Qt環(huán)境變量,實(shí)現(xiàn)靈活且可控的開發(fā)體驗(yàn),所以本文介紹了Windows配置Qt環(huán)境變量的全指南
    2025-07-07
  • C++ Eigen庫實(shí)現(xiàn)最小二乘擬合的示例代碼

    C++ Eigen庫實(shí)現(xiàn)最小二乘擬合的示例代碼

    Eigen 是一個(gè)線性算術(shù)的 C++ 模板庫,功能強(qiáng)大、快速、優(yōu)雅以及支持多平臺(tái),本文主要為大家介紹了C++利用Eigen庫實(shí)現(xiàn)最小二乘擬合的示例代碼,希望對(duì)大家有所幫助
    2023-07-07
  • C語言中const和define的區(qū)別你了解嘛

    C語言中const和define的區(qū)別你了解嘛

    這篇文章主要為大家詳細(xì)介紹了C語言中const和define的區(qū)別,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • OpenCV實(shí)戰(zhàn)之基于Hu矩實(shí)現(xiàn)輪廓匹配

    OpenCV實(shí)戰(zhàn)之基于Hu矩實(shí)現(xiàn)輪廓匹配

    這篇文章主要介紹了利用C++ OpenCV實(shí)現(xiàn)基于Hu矩的輪廓匹配,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定的幫助,感興趣的可以學(xué)習(xí)一下
    2022-01-01
  • C語言實(shí)現(xiàn)簡易通訊錄

    C語言實(shí)現(xiàn)簡易通訊錄

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡易通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • C語言 從根本上理解指針

    C語言 從根本上理解指針

    C語言這門課程在計(jì)算機(jī)的基礎(chǔ)教學(xué)中一直占有比較重要的地位,然而要想突破C語言的學(xué)習(xí),對(duì)指針的掌握是非常重要的,本文將具體針對(duì)指針的基礎(chǔ)做詳盡的介紹
    2022-04-04
  • C++中AVL樹的底層以及實(shí)現(xiàn)方法總結(jié)

    C++中AVL樹的底層以及實(shí)現(xiàn)方法總結(jié)

    這篇文章主要介紹了C++中AVL樹的底層以及實(shí)現(xiàn)方法的相關(guān)資料,AVL樹是一種自平衡的二叉搜索樹,每個(gè)節(jié)點(diǎn)的左右子樹高度差不超過1,通過旋轉(zhuǎn)操作保持平衡,詳解了AVL樹的結(jié)構(gòu)、插入、旋轉(zhuǎn)、查找和遍歷方法,展示了其保持平衡的機(jī)制及對(duì)應(yīng)代碼實(shí)現(xiàn),需要的朋友可以參考下
    2024-10-10
  • 一文掌握scanf的用法實(shí)例小結(jié)

    一文掌握scanf的用法實(shí)例小結(jié)

    scanf的基本用法除了常規(guī)的輸入操作外還有一些特殊的用法,使用這些用法可以很方便的在輸入中讀取想要的數(shù)據(jù),這篇文章主要介紹了scanf的用法,需要的朋友可以參考下
    2023-12-12
  • C++如何將二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表(雙指針或數(shù)組)

    C++如何將二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表(雙指針或數(shù)組)

    這篇文章主要介紹了C++如何將二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表(雙指針或數(shù)組),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • C語言實(shí)現(xiàn)維吉尼亞密碼的示例代碼

    C語言實(shí)現(xiàn)維吉尼亞密碼的示例代碼

    維吉尼亞密碼(又譯維熱納爾密碼)是使用一系列凱撒密碼組成密碼字母表的加密算法,屬于多表密碼的一種簡單形式。本文將用C語言實(shí)現(xiàn)維吉尼亞密碼,需要的可以參考一下
    2022-11-11

最新評(píng)論