0.c++-static_cast、reinterpret_cast、dynamic_cast、等转换

static_cast:

可以实现C++中内置基本数据类型之间的相互转换。如果涉及到类的话,static_cast只能在有相互联系的类型中进行相互转换,不一定包含虚函数

class A{};
class B:public A{};
class C{};
int main(){
	A* a=new A;
	B* b;
	C* c;
	b=static_cast<B>(a);  // 编译不会报错, B类继承A类
	c=static_cast<B>(a);  // 编译报错, C类与A类没有任何关系
	return 1;
}</span>

const_cast: 

const_cast操作不能在不同的种类间转换。相反,它仅仅把一个它作用的表达式转换成常量。它可以使一个本来不是const类型的数据转换成const类型的,或者把const属性去掉。

reinterpret_cast: 

有着和C风格的强制转换同样的能力。它可以转化任何内置的数据类型为其他任何的数据类型,也可以转化任何指针类型为其他的类型。它甚至可以转化内置的数据类型为指针,无须考虑类型安全或者常量的情形。不到万不得已绝对不用。

dynamic_cast: 

(1)其他三种都是编译时完成的,dynamic_cast是运行时处理的,运行时要进行类型检查。
(2)不能用于内置的基本数据类型的强制转换。
(3)dynamic_cast转换如果成功的话返回的是指向类的指针或引用,转换失败的话则会返回NULL。
(4)使用dynamic_cast进行转换的,基类中一定要有虚函数,否则编译不通过。
需要检测有虚函数的原因:类中存在虚函数,就说明它有想要让基类指针或引用指向派生类对象的情况,此时转换才有意义。只有定义了虚函数的类才有虚函数表。
 (5)在类的转换时,在类层次间进行上行转换时,dynamic_cast和static_cast的效果是一样的。在进行下行转换时,dynamic_cast具有类型检查的功能,比 static_cast更安全。向上转换即即将父类指针转化子类指针。向下转换的成功与否还与将要转换的类型有关,即要转换的指针指向的对象的实际类型与转换以后的对象类型一定要相同,否则转换失败。

class A{
	public:
	virtual void foo(){
		std::cout<<"A::foo"<<std::endl;
	}
};
 
class B{
	public:
	virtual void bar(){
		std::cout<<"B::bar"<<std::endl;
	}
};
 
class C : public A, public B{
	public:
	void foo(){
		std::cout<<"C::foo"<<std::endl;
	}
	void bar(){
		std::cout<<"C::bar"<<std::endl;
	}
};
 
int main(){
	A *a = new C;
	a->foo();
	B *b = dynamic_cast<B*>(a);
	b->bar();
	return 0;
}
</span>

结果:

C::foo
C::bar





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值