函数typeid()返回值类型class type_info。
其中type_info重载了操作符==, !=, =分别用来比较是否相等、不等、赋值。
函数name()返回类型名称。
class type_info {
public:
virtual ~type_info();
booloperator== (consttype_info& rhs) const;
booloperator!= (consttype_info& rhs) const;
boolbefore (consttype_info& rhs) const;
constchar* name() const;
private:
type_info (consttype_info& rhs);
type_info& operator= (consttype_info& rhs);
};
当类型是类和类指针时需要注意:
正常类基类指针base*指向继承类deived,则typeid(deived) != typeid(*base) 前者类型是继承类的type_info类型,而后者是父类的type_info类型。
虚类基类指针base*指向继承类deived,则typeid(deived) == typeid(*base) 两者都是父类的type_info类型。
// type_info example
#include <iostream>
#include <typeinfo>
using namespace std;
struct Base {};
struct Derived : Base {};
struct Poly_Base {virtual void Member(){}};
struct Poly_Derived: Poly_Base {};
int main() {
// built-in types:
int i;
int * pi;
cout << "int is: " << typeid(int).name() << endl;
cout << " i is: " << typeid(i).name() << endl;
cout << " pi is: " << typeid(pi).name() << endl;
cout << "*pi is: " << typeid(*pi).name() << endl << endl;
// non-polymorphic types:
Derived derived;
Base* pbase = &derived;
cout << "derived is: " << typeid(derived).name() << endl;
cout << " *pbase is: " << typeid(*pbase).name() << endl;
cout << boolalpha << "same type? ";
cout << ( typeid(derived)==typeid(*pbase) ) << endl << endl;
// polymorphic types:
Poly_Derived polyderived;
Poly_Base* ppolybase = &polyderived;
cout << "polyderived is: " << typeid(polyderived).name() << endl;
cout << " *ppolybase is: " << typeid(*ppolybase).name() << endl;
cout << boolalpha << "same type? ";
cout << ( typeid(polyderived)==typeid(*ppolybase) ) << endl << endl;
}
原文链接: https://www.cnblogs.com/visayafan/archive/2011/11/29/2268135.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/37496
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!