對C語言中sizeof細(xì)節(jié)的三點(diǎn)分析介紹
1.sizeof是運(yùn)算符,跟加減乘除的性質(zhì)其實(shí)是一樣的,在編譯的時候進(jìn)行執(zhí)行,而不是在運(yùn)行時才執(zhí)行。
那么如果編程中驗證這一點(diǎn)呢?ps:這是前兩天朋友淘寶面試的一道題,小編理解:
#include<iostream>
using namespace std;
int main()
{
int i=1;
cout<<i<<endl;
sizeof(++i);
cout<<i<<endl;
return 1;
}
輸入結(jié)果為 1
1
sizeof中的++i 的副作用并沒有顯示出來,原因只可能有一個,在編譯的時候sizeof執(zhí)行以后將++i 處理了,++i 的副作用因此被消除了。如果sizeof 是在運(yùn)行時進(jìn)行的話,則肯定要注意++i 。實(shí)際上sizeof的實(shí)現(xiàn)應(yīng)該是用宏來做的,宏在編譯時進(jìn)行執(zhí)行。具體實(shí)現(xiàn)可以參考下面。
2.sizeof('a')在C語言中的結(jié)果是4,在C++中結(jié)果是1,看過某篇文章說C中sizeof側(cè)重于“數(shù)”,而C++中sizeof更側(cè)重于“字符”。
3.文章中講了兩個用宏實(shí)現(xiàn)sizeof的經(jīng)典應(yīng)用
//適用于非數(shù)組
#define _sizeof(T) ((size_t)((T*)0 + 1))
//適用于數(shù)組
#define array_sizeof(T) ((size_t)(&T+1)-(size_t)(&T))
先舉兩個小例子說明兩個宏的應(yīng)用,對于第一個如 _sizeof(int); 的結(jié)果就是4;對于第二個先聲明一個大小為4的數(shù)組int a[4];那么array_sizeof(a)結(jié)果為16.
對于非數(shù)組的宏定義,先是將0轉(zhuǎn)換為T*類型的指針?biāo)赶虻牡刂罚ù藭r地址為0)。然后對T類型的地址加1,相當(dāng)于加上了T類型的大?。吹玫搅朔菙?shù)組T的大?。?。前面的size_t只是將地址轉(zhuǎn)化為int型的整數(shù)返回。
一個簡單的例子:int* p; p=p+1; --------p是一個int*類型的指針, p+1在地址空間上相當(dāng)于加上了4個字節(jié)。
對于數(shù)組的宏定義,類似于非數(shù)組的宏定義,為了方便理解,這里可以把數(shù)組T看成一個用戶自定義的類型,&T表示數(shù)組類型的指針,對于數(shù)組類型指針加1相當(dāng)于在地址上加上了該數(shù)組大小。由于是用戶自定義的類型所以不能強(qiáng)制將0轉(zhuǎn)化為數(shù)組類型的地址,只能用加1后的地址減去之前的地址,得到的差值就是數(shù)組本身所占的字節(jié)大小。
相關(guān)文章
詳解C語言中accept()函數(shù)和shutdown()函數(shù)的使用
這篇文章主要介紹了詳解C語言中accept()函數(shù)和shutdown()函數(shù)的使用,用來操作socket相關(guān)的網(wǎng)絡(luò)通信,需要的朋友可以參考下2015-09-09C++超詳細(xì)講解內(nèi)存空間分配與this指針
this?指針在C++類和對象中是個很方便實(shí)用的關(guān)鍵字,可以簡化對象成員屬性的調(diào)用,使代碼表達(dá)的含義更加準(zhǔn)確;在之前的學(xué)習(xí)中我們都可以判斷變量所占內(nèi)存空間大小,那么我們創(chuàng)建的類對象所占的內(nèi)存空間怎么計算呢?想知道this的妙用和類對象占用的內(nèi)存空間就來跟我學(xué)習(xí)吧2022-05-05C++?OpenCV實(shí)現(xiàn)物體尺寸測量示例詳解
本文主要介紹了利用OpenCV對物體的尺寸進(jìn)行測量,即先定位到待測物體的位置,然后測量物體的寬高。感興趣的同學(xué)可以跟隨小編一起學(xué)習(xí)學(xué)習(xí)2022-01-01