(C/C++学习笔记) 二十三. 运行时类型识别
二十三. 运行时类型识别
● 定义
|
运行时类型识别(Run-time Type Identification, RTTI) |
|
通过RTTI, 程序能够使用基类的指针或引用来检查(check)这些指针或引用所指对象的实际派生类型. C++通过下面两个操作符提供RTTI: ① typeid操作符, 返回指针或引用所指对象的实际类型; ② dynamic_cast操作符, 将基类类型的指针或引用安全地转换为派生类型的指针或引用. |
● 基类指针访问子类的特有成员函数
|
#include <iostream> using namespace std; class Base { public: virtual char* GetName()=0; }; class Bint:public Base { public: char * GetName() {return "Bint";} int GetInt() {return 1;} }; class BString:public Base { public: char* GetName() {return "BString";} char* GetString() {return "Hello";} }; int main(int argc, char* argv[]) { Base* B1 = new Bint(); //也可以写成Base* B1 = (Base*)new Bint(); 但这里的(Base*)其实是多余的 printf(B1->GetName()); printf("\n"); //////////////////////////////////////////////////////////////// Bint *B2= static_cast<Bint*>(B1); //下面要用基类指针B1来访问子类Bint的特有方法GetInt(), 我们首先要将B1静态转换为Bint型 if(B2) printf("%d", B2->GetInt()); printf("\n"); //////////////////////////////////////////////////////////////// Base * C1 = new BString(); printf(C1->GetName()); printf("\n"); //////////////////////////////////////////////////////////////// BString *C2 = static_cast<BString *>(C1); if(C2) printf(C2->GetString()); printf("\n"); return 0; }
|
● RTTI与虚继承
|
如果使用了虚继承, 将子类对象的地址赋值给基类指针, 此时, 基类指针仍可识别为它所指的子类对象的实际类型. ※ RTTI (Runtime Type Identification) 运行时类型识别 typeid 是一个用于运行时类型识别的操作符, 它返回的是type_info类型的常引用, type_info是C++标准库的一个类. 使用typeid注意使用头文件typeinfo.h |
|
#include <iostream> #include <typeinfo> using namespace std; class Animal { public: virtual void display(){} }; class Cow:public Animal{}; class Dog:public Animal {}; int main(){ Animal *anm; Cow cw; Dog dg; cout << "type of anm is : "<<typeid(anm).name()<<endl; cout << "type of cw is : "<<typeid(cw).name()<<endl; cout << "type of dg is : "<<typeid(dg ).name()<<endl; // initializing base pointer with the address of a derived class object; anm = &cw; cout<<"type of *anm when pointing to cw is: "<<typeid(*anm).name()<<endl; anm = &dg; cout<<"type of *anm when pointing to dg is: "<<typeid(*anm).name()<<endl; system("PAUSE"); return 0; } |
|
|
● 标准C++的类型转换符
|
对于强制类型转换的风险, 最好的解决方法就是不要使用C风格的强制类型转换,而是使用标准C++的类型转换符:static_cast、dynamic_cast、reinterpret_cast、和const_cast。 用法: dynamic_cast < typeid > ( expression ); 以此类推 ※ 所有的cast操作符都是针对 指针或引用 来转换的,不能对普通类型进行操作. ① static_cast 进行上行转换(把子类的指针或引用转换成基类表示)是安全的;进行下行转换(把基类指针或引用转换成子类表示)时,由于没有动态类型检查(check),所以是不安全的。 ② dynamic_cast 进行上行转换时,dynamic_cast和static_cast的效果是一样的;在进行下行转换时,dynamic_cast具有类型检查的功能,比static_cast更安全 ③ reinterpret_cast 将某一类型转换为原来的类型 #include "iostream.h" int main(int argc, char* argv[]) { int n = 97; char p[4] = {0}; 个元素 cout<<p<<endl; 个元素)的地址转换成原来的整型指针 cout<<*f<<endl; return 0; }
④const_cast 强制将一个const变量(只读变量)变成一个非const的等价形式(即并不就是把某个const变量转换为一般的变量) #include <iostream> using namespace std; int main(int argc, char* argv[]) { const int a=1; int* b=const_cast<int*>(&a); //不能是int b=const_cast<int>(a) * b=2; //const变量a的等价形式是*b cout<<* b<<endl; }
|
● 数组和向量
|
在计算机领域, 一维数组(single-dimensional array)=向量(能自己管理内存,又不限长度); 二维数组(2-dimensional array)=矩阵 ※"之所以选择'vector'这个名字,是因为Alex Stepanov作为C++标准库的设计者当初在寻找一个可以与内置数组类型区分开来的名字的时候,使用了"向量"这个表示; 他现在承认这确实是个错误,因为数学家们通常使用"向量"来表示一个定长的序列。 |
● 向量
|
向量的定义方式有四种: vector<int> a(10); vector<int> b(10, 1); vector<int> c(b); vector<int> d(b.begin(), b.begin()+3);
如果要输出向量中的所有元素, 可以有两种循环控制方式: //第一种: for (int i=0; i<a.size(); i++) cout<<a[i]<<" "; //第二种: for (vector<int>::iterator it=a.begin(); it!=a.end(); ++it) cout<<*it<<" "; |
(C/C++学习笔记) 二十三. 运行时类型识别的更多相关文章
- MFC六大核心机制之二:运行时类型识别(RTTI)
上一节讲的是MFC六大核心机制之一:MFC程序的初始化,本节继续讲解MFC六大核心机制之二:运行时类型识别(RTTI). typeid运算子 运行时类型识别(RTTI)即是程序执行过程中知道某个对象属 ...
- python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码
python3.4学习笔记(二十三) Python调用淘宝IP库获取IP归属地返回省市运营商实例代码 淘宝IP地址库 http://ip.taobao.com/目前提供的服务包括:1. 根据用户提供的 ...
- C++学习之显式类型转换与运行时类型识别RTTI
static_cast const_cast reinterpret_cast 运行时类型识别(RTTI) dynamic_cast 哪种情况下dynamic_cast和static_cast使用的情 ...
- RTTI (Run-Time Type Identification,通过运行时类型识别) 转
参考一: RTTI(Run-Time Type Identification,通过运行时类型识别)程序能够使用基类的指针或引用来检查这些指针或引用所指的对象的实际派生类型. RTTI提供了以下两个 ...
- 框架原理第二讲,RTTI,运行时类型识别.(以MFC框架讲解)
框架原理第二讲,RTTI,运行时类型识别.(以MFC框架讲解) 一丶什么是RTTI,以及RTTI怎么设计 通过第一讲,我们知道了怎么样升成一个窗口了,以及简单的消息循环. 第二讲则是主要讲解RTTI ...
- MFC原理第三讲.RTTI运行时类型识别
MFC原理第三讲.RTTI运行时类型识别 一丶什么是RTTI RTTI. 运行时的时候类型的识别. 运行时类型信息程序.能够使用基类(父类)指针 或者引用 来检查这些指针或者引用所指的对象. 实际派生 ...
- 《深入浅出MFC》系列之运行时类型识别(RTTI)
/********************************************************************************** 发布日期:2017-11-13 ...
- RTTI 运行时类型识别 及异常处理
RTTI 运行时类型识别 typeid ------ dynamic_cast dynamic_cast 注意事项: 1.只能应用于指针和引用之间的转化 2.要转换的类型中必须包含虚函数 3. ...
- c++运行时类型识别(rtti)
一个简单运行时类型识别 namespace rtti_ex { /* * 类型信息基类 */ class i_type_info { public: // 判断是否是指定类型 bool is(cons ...
随机推荐
- 编写脚本,出现 TypeError: exceptions must be old-style classes or derived from BaseException, not unicode怎样解决?
小编使用robot framework,在编写安卓自动化脚本时,出现这样的情况: 在网上搜了好久,发现都是python的解决方法,到底怎样解决robot里面的问题呢?最终发现: (1)代码中我是这样写 ...
- 最短路径遍历所有的节点 Shortest Path Visiting All Nodes
2018-10-06 22:04:38 问题描述: 问题求解: 本题要求是求遍历所有节点的最短路径,由于本题中是没有要求一个节点只能访问一次的,也就是说可以访问一个节点多次,但是如果表征两次节点状态呢 ...
- idea maven环境下 java实现发送邮件验证
1.开通smtp授权 QQ邮箱-设置-账户-开启 得到一个授权码 2.下载javax.email包 maven项目中 pom文件加入: <dependency> <groupId&g ...
- 雷林鹏分享:C# 变量
C# 变量 一个变量只不过是一个供程序操作的存储区的名字.在 C# 中,每个变量都有一个特定的类型,类型决定了变量的内存大小和布局.范围内的值可以存储在内存中,可以对变量进行一系列操作. 我们已经讨论 ...
- anaconda安装tensorflow
1.下载anaconda python3.5版本,Windows不支持python3.6,linux和mac支持python2.7和python3.3+ 2.创建环境 conda create - ...
- MyBatis中mybatis-generator代码生成的一般过程
MyBatis框架的使用,可以参考我的文章: https://blog.csdn.net/JayInnn/article/details/81746571(基于Mybatis实现一个查库的接口) ht ...
- shiro会话管理
Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如web容器tomcat),不管JavaSE还是JavaEE环境都可以使用,提供了会话管理.会话事件监听.会话存储/持久化.容器无关的集群. ...
- const constptr 和引用的盲点(未解决)
#include<iostream> //const 和 引用的值必须初始化 //等号左侧是const或者const和引用,右侧可以是数字,普通变量-等号左侧是const和指针,右侧必须是 ...
- 媒体查询漫谈——@media Queries
通过不同的媒体类型和条件定义样式表规则.媒体查询让CSS可以更精确作用于不同的媒体类型和同一媒体的不同条件.媒体查询的大部分媒体特性都接受min和max用于表达”大于或等于”和”小与或等于”.如:wi ...
- Leetcode 127 **
class Solution { public: int ladderLength(string beginWord, string endWord, vector<string>& ...





