詳解C++編程中的sizeof運(yùn)算符與typeid運(yùn)算符
sizeof 運(yùn)算符
產(chǎn)生與 char 類型的大小有關(guān)的操作數(shù)大小。
語法
sizeof unary-expression sizeof ( type-name )
備注
sizeof 運(yùn)算符的結(jié)果為 size_t 類型,它是包含文件 STDDEF.H 中定義的整數(shù)類型。利用此運(yùn)算符,你可以避免在程序中指定依賴于計算機(jī)的數(shù)據(jù)大小。
sizeof 的操作數(shù)可以是下列項之一:
類型名稱。若要將 sizeof 用于類型名稱,則該名稱必須用括號括起。
一個表達(dá)式。當(dāng)用于表達(dá)式時,無論是否使用括號都可指定 sizeof。不計算表達(dá)式。
當(dāng) sizeof 運(yùn)算符應(yīng)用到 char 類型的對象時,它將生成 1。當(dāng) sizeof 運(yùn)算符應(yīng)用到數(shù)組時,它將產(chǎn)生該數(shù)組的字節(jié)總數(shù),而非由數(shù)組標(biāo)識符表示的指針的大小。若要獲取由數(shù)組標(biāo)識符表示的指針的大小,請將其作為參數(shù)傳遞給使用 sizeof 的函數(shù)。例如:
#include <iostream> using namespace std; size_t getPtrSize( char *ptr ) { return sizeof( ptr ); } int main() { char szHello[] = "Hello, world!"; cout << "The size of a char is: " << sizeof( char ) << "\nThe length of " << szHello << " is: " << sizeof szHello << "\nThe size of the pointer is " << getPtrSize( szHello ) << endl; }
示例輸出
The size of a char is: 1 The length of Hello, world! is: 14 The size of the pointer is 4
當(dāng) sizeof 運(yùn)算符應(yīng)用到 class、struct 或 union 類型時,結(jié)果為該類型的對象中的字節(jié)數(shù),以及添加的用于在字邊界上對齊成員數(shù)據(jù)的任何填充。結(jié)果不一定對應(yīng)于通過將各個成員的存儲需求相加計算出的大小。 /Zp 編譯器選項和 pack 雜注會影響成員的對齊邊界。
sizeof 運(yùn)算符永遠(yuǎn)不會產(chǎn)生 0,即使對于空類也是如此。
sizeof 運(yùn)算符不能用于以下操作數(shù):
函數(shù)。(但是,sizeof 可應(yīng)用于指向函數(shù)的指針。)
位域。
未定義的類。
void 類型。
動態(tài)分配的數(shù)組。
外部數(shù)組。
不完整類型。
帶括號的不完整類型的名稱。
當(dāng) sizeof 運(yùn)算符應(yīng)用于引用時,結(jié)果與 sizeof 應(yīng)用到對象本身時的結(jié)果相同。
如果某個未確定大小的數(shù)組是結(jié)構(gòu)的最后一個元素,則 sizeof 運(yùn)算符將返回沒有該數(shù)組的結(jié)構(gòu)的大小。
sizeof 運(yùn)算符通常用于通過使用以下形式的表達(dá)式計算數(shù)組中的元素數(shù)量:
sizeof array / sizeof array[0]
typeid 運(yùn)算符
語法
typeid( type-id ) typeid( expression ) ( expression )
備注
typeid 運(yùn)算符允許在運(yùn)行時確定對象的類型。
typeid 的結(jié)果是 const type_info&。該值是對表示 type-id 或 expression 的類型的 type_info 對象的引用,具體取決于所使用的 typeid 的形式。
typeid 運(yùn)算符不適用于托管類型(抽象聲明符或?qū)嵗?br />
typeid 運(yùn)算符在應(yīng)用于多態(tài)類類型的左值時執(zhí)行運(yùn)行時檢查,其中對象的實際類型不能由提供的靜態(tài)信息確定。此類情況是:
對類的引用
使用 * 取消引用的指針
帶下標(biāo)的指針(即 [ ])。(請注意,通常情況下,將下標(biāo)與指向多態(tài)類型的指針一起使用不安全。)
如果 expression 指向基類類型,但該對象實際上是派生自該基類的類型,則派生類的 type_info 引用是結(jié)果。 expression 必須指向多態(tài)類型(具有虛函數(shù)的類)。否則,結(jié)果是 expression 中引用的靜態(tài)類的 type_info。此外,必須取消引用指針以使用它指向的對象。如果未取消引用指針,結(jié)果將是指針的 type_info,而不是它指向的內(nèi)容。例如:
// expre_typeid_Operator.cpp // compile with: /GR /EHsc #include <iostream> #include <typeinfo.h> class Base { public: virtual void vvfunc() {} }; class Derived : public Base {}; using namespace std; int main() { Derived* pd = new Derived; Base* pb = pd; cout << typeid( pb ).name() << endl; //prints "class Base *" cout << typeid( *pb ).name() << endl; //prints "class Derived" cout << typeid( pd ).name() << endl; //prints "class Derived *" cout << typeid( *pd ).name() << endl; //prints "class Derived" delete pd; }
如果 expression 正在取消引用某個指針,并且該指針的值是零, typeid 將引發(fā) bad_typeid 異常。如果該指針沒有指向有效的對象,則會引發(fā) __non_rtti_object 異常來指示嘗試了分析引發(fā)錯誤(如訪問沖突)的 RTTI,因為該對象在某種程度上是無效的(無效的指針或代碼不是用 /GR 編譯的)。
如果 expression 既不是指針也不是對對象的基類的引用,則結(jié)果是表示 expression 的靜態(tài)類型的 type_info 引用。表達(dá)式的 static type 將引用在編譯時已知的表達(dá)式的類型。在計算表達(dá)式的靜態(tài)類型時,將忽略執(zhí)行語義。此外,在確定表達(dá)式的靜態(tài)類型時,將忽略引用(如果可能):
// expre_typeid_Operator_2.cpp #include <typeinfo> int main() { typeid(int) == typeid(int&); // evaluates to true } typeid 還可在模板中使用以確定模板參數(shù)的類型: // expre_typeid_Operator_3.cpp // compile with: /c #include <typeinfo> template < typename T > T max( T arg1, T arg2 ) { cout << typeid( T ).name() << "s compared." << endl; return ( arg1 > arg2 ? arg1 : arg2 ); }
相關(guān)文章

Cocos2d-x保存用戶游戲數(shù)據(jù)之XML文件是否存在問題判斷方法

C++ 關(guān)于 CMFCPropertyGridCtrl 的使用方法

C++深入講解new與deleted關(guān)鍵字的使用