sizeof操作符使用注意:
先看下面的測試代碼(1)和(2):
=====================================================================
測試代碼(1) :
const char* a[] = { "a", "bcedf" };
// 測試下面的sizeof(a),它的結(jié)果是’8’, 原因在于a是指針數(shù)組,里面存儲的是指針元素。
// 在這里是兩個指針元素的數(shù)組。故為4*2=8.
cout << sizeof(a) << endl; // print '8'
// test sizeof(*a), sizeof(a[0]), sizeof(a[0][0])
cout << sizeof(*a) << endl; // print '4' 這里*a是求出第一個字符串的地址,注意a是指針的指針。
cout << sizeof(a[0]) << endl;// print '4' 這里是a[0] = *a,跟上面的一樣。
cout << sizeof(a[0][0]) << endl; // print '1' 這里是第一個字符串的第一個字符a,一個字節(jié)。
測試代碼(2) :
struct TestStruct {
char c_elem; // 1 bytes
int int_elem; // 4 bytes
};
cout << sizeof(TestStruct) << endl; // it prints '8' .
struct TestStruct1 {
char c_elem1;
char c_elem2:
char c_elem3;
... // num 個char類型數(shù)據(jù)成員
};
cout << sizeof(TestStruct1) <<endl; // it prints num.
// 輸出的結(jié)果與具體的系統(tǒng)結(jié)構(gòu)有關(guān),此處是32位機(jī),故為了尋址的快捷和方便,系統(tǒng)會自動的填補(bǔ)(padding).
// int類型是4個字節(jié),char類型為1個字節(jié),但是此處會自動填補(bǔ)3個字節(jié)到struct結(jié)構(gòu)中使其成為4個字節(jié)。
// 但是如果struct中只有一種類型,譬如char或int類型時,不會產(chǎn)生此種填補(bǔ)的情況。但是如果不是,它會輸出
// 4的倍數(shù)個字節(jié)。
======================================================================