打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
RTTI
1、强制类型转换第一个例子:
(1)、main函数中还可以定义类
(2)、typeid(1.1f) ==  typeid(0.0f)
(3)、指针强制转化失败后可以比较指针是否为零,而引用却没办法,所以引用制转化失败后抛出异常
(4)、对引用的强制转换 dynamic_cast<Derive22&>(b2);


#include <iostream>
using namespace std;
int main( void )
{
// sample 1
cout << typeid(1.1f).name() << endl;
// sample 2
class Base1
{
};
class Derive1 : public Base1
{
};
Derive1 d1;
Base1& b1 = d1;
cout << typeid(b1).name() << endl; // 输出"class Base1",因为Derive1和Base1之间没有多态性
// sample 3, 编译时需要加参数 /GR
class Base2
{
virtual void fun( void ) {}
};
class Derive2 : public Base2
{
};
Derive2 d2;
Base2& b2 = d2;
cout << typeid(b2).name() << endl; // 输出"class Derive2",因为Derive1和Base1之间有了多态性
// sample 4
class Derive22 : public Base2
{
};
// 指针强制转化失败后可以比较指针是否为零,而引用却没办法,所以引用制转化失败后抛出异常
Derive2* pb1 = dynamic_cast<Derive2*>(&b2);
cout << boolalpha << (0!=pb1) << endl; // 输出"true",因为b2本身确实是指向Derive2
Derive22* pb2 = dynamic_cast<Derive22*>(&b2);
cout << boolalpha << (0!=pb2) << endl; // 输出"false",因为b2本身不是指向Derive22
try {
Derive2& rb1 = dynamic_cast<Derive2&>(b2);
cout << "true" << endl;
} catch( bad_cast )
{
cout << "false" << endl;
}
try {
Derive22& rb2 = dynamic_cast<Derive22&>(b2);
cout << "true" << endl;
catch( ... ) // 应该是 bad_cast,但不知道为什么在VC++6.0中却不行?因为VC++6.0默认状态是禁用 RTTI 的,启用方式:project->setting->c/c++->category->c++ Language 下面第二个复选框选中。
{
cout << "false" << endl;
}
return 0;
}

2、第二个例子
#include <iostream>
#include <typeinfo>
#include <vector>
#include <string>
using namespace std;

template<typename T>
void foo(const T& t)
{
cout << "foo: generic(" << t << ") " << typeid(t).name() << endl;
}

template<typename T>
void bar(const T t)
{
cout << "bar: generic(" << t << ") " << typeid(t).name() << endl;
}

int main()
{
foo("");                              // foo: generic() A1_c
foo("0");                             // foo: generic(0) A2_c
foo("01");                            // foo: generic(01) A3_c
foo(static_cast<string>(""));         // foo: generic() Ss
foo(static_cast<string>("0"));        // foo: generic(0) Ss
foo(static_cast<string>("01"));       // foo: generic(01) Ss
foo(static_cast<const char *>(""));   // foo: generic() PKc
foo(static_cast<const char *>("0"));  // foo: generic(0) PKc
foo(static_cast<const char *>("01")); // foo: generic(01) PKc
foo(*(new string("")));               // foo: generic() Ss
foo(*(new string("0")));              // foo: generic(0) Ss
foo(*(new string("01")));             // foo: generic(01) Ss
bar("");                              // foo: generic() PKc
bar("0");                             // foo: generic(0) PKc
bar("01");                            // foo: generic(01) PKc
bar(static_cast<string>(""));         // foo: generic() Ss
bar(static_cast<string>("0"));        // foo: generic(0) Ss
bar(static_cast<string>("01"));       // foo: generic(01) Ss
bar(static_cast<const char *>(""));   // foo: generic() PKc
bar(static_cast<const char *>("0"));  // foo: generic(0) PKc
bar(static_cast<const char *>("01")); // foo: generic(01) PKc
bar(*(new string("")));               // foo: generic() Ss
bar(*(new string("0")));              // foo: generic(0) Ss
bar(*(new string("01")));             // foo: generic(01) Ss
return 0;
}

/*
$ c++filt [-t] A1_c A2_c A3_c Ss PKc
char [1]
char [2]
char [3]
std::basic_string<char, std::char_traits<char>, std::allocator<char> >
char const*
*/
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
数据类型转换
c – static_cast(* this)和static_cast(* this)之间的区别
C++的类型转换
类大小sizeof(class)
关于typeid —— typeid和RTTI C++
利用C 模板,代替虚函数,实现类的静态多态性(加入性能测试部分) - woaidongmao - C 博客
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服