typeid的用法相对简单, 它可以接受各种的输入,class type,object var, pointer. 他的作用就是得到一个typeinfo类型的返回类对象; 你可以用typeid(xxx).name()来查看这个名字.也可以用==来比较这个typeinfo.
主要要注意的,对于多态指针引用的对象, 他会返回起源子类的名字, 而不是这个类的生命类型. 仅此而已.
总结如下:
typeid(class) --> class name
typeid(object) --> class name
typeid(object ) -> pointer class name like PDriver
typeid( pobject) --> if it’s polymorphic, it’s drived class name, or else it’s current class name.
typeeid(object &) --> class name
以下程序,修改于其他网友的修改.
#define OUTPUT(f) cout << #f << "\t: " << typeid(f).name() << endl;
class BaseA {
int a1;
};
class DeriveA: public BaseA {
int a2;
};
class BaseB
{
virtual void f(){};
int b1;
};
class DeriveB: public BaseB {
int b2;
};
int main()
{
cout << “-------直接处理类名-------” <<endl;
OUTPUT(BaseA);
OUTPUT(DeriveA);
OUTPUT(BaseB);
OUTPUT(DeriveB);
cout << endl << "-------基类不含虚函数-------" <<endl;
BaseA baseA;
DeriveA deriveA;
OUTPUT(baseA);
OUTPUT(deriveA);
BaseA* pa;
pa = &baseA;
OUTPUT(*pa);
OUTPUT(pa);
pa = &deriveA;
OUTPUT(*pa);
OUTPUT(pa);
BaseA &ba2 = deriveA;
DeriveA &da2 = deriveA;
OUTPUT(ba2);
OUTPUT(da2);
cout << endl << "-------基类含有虚函数-------" <<endl;
BaseB baseB;
DeriveB deriveB;
OUTPUT(baseB);
OUTPUT(deriveB);
BaseB* pb;
pb = &baseB;
OUTPUT(*pb);
OUTPUT(pb);
pb = &deriveB;
OUTPUT(*pb);
OUTPUT(pb);
}
输出如下:
-------直接处理类名-------
BaseA : 5BaseA
DeriveA : 7DeriveA
BaseB : 5BaseB
DeriveB : 7DeriveB
-------基类不含虚函数-------
baseA : 5BaseA
deriveA : 7DeriveA
*pa : 5BaseA
pa : P5BaseA
*pa : 5BaseA
pa : P5BaseA
ba2 : 5BaseA
da2 : 7DeriveA
-------基类含有虚函数-------
baseB : 5BaseB
deriveB : 7DeriveB
*pb : 5BaseB
pb : P5BaseB
*pb : 7DeriveB
pb : P5BaseB
本文深入探讨了C++中的typeid操作符,展示了其在处理类类型、对象和指针时的行为。通过实例代码,说明了typeid如何返回typeinfo对象,并通过.name()方法获取类名。在多态性上下文中,typeid会返回子类的名称而非基类的名称。文章总结了typeid在不同情况下的输出结果,帮助理解其在非虚函数和虚函数场景下的差异。
851

被折叠的 条评论
为什么被折叠?



