C++基类和派生类的智能指针转换:static_pointer_cast、dynamic_pointer_cast、const_pointer_cast、reinterpret_pointer_cast
当我们用“裸”指针进行类层次上的上下行转换时,可以使用dynamic_cast。当然我们也可以使用static_cast,只是dynamic_cast在进行下行转换的时候(即基类到派生类)具有类型检查功能,而static_cast没有。因此存在安全问题。
当我们使用智能指针时,如果需要进行类层次上的上下行转换时,可以使用std::static_pointer_cast()、std::dynamic_pointer_cast、std::const_pointer_cast()和std::reinterpret_pointer_cast()。它们的功能和std::static_cast()、std::dynamic_cast、std::const_cast()和std::reinterpret_cast()类似,只不过转换的是智能指针std::shared_ptr,返回的也是std::shared_ptr类型。
1、std::static_pointer_cast():当指针是智能指针时候,向上转换,用static_cast 则转换不了,此时需要使用static_pointer_cast。
2、std::dynamic_pointer_cast():当指针是智能指针时候,向下转换,用dynamic_cast 则转换不了,此时需要使用dynamic_pointer_cast。
3、std::const_pointer_cast():功能与std::const_cast()类似
4、std::reinterpret_pointer_cast():功能与std::reinterpret_cast()类似
一、static_cast:静态转换,基本类型转换,不相关类型不可以转换;
例如:
二、reinterpret_cast:强制转换,两个没有任何关系的指针或者引用之间转换;
例如:
三、dynamic_cast:动态转换,多态的类型(指针或者引用)转换;
如果有A, B俩个类,B类继承A类。A类中可能存在虚函数。
(1)其他三种都是编译时完成的,dynamic_cast是运行时处理的,运行时要进行类型检查。
①如果是子类转父类:dynamic_cast和static_cast效果是一样的;
②如果是父类转子类:dynamic_cast比static_cast更安全,具有类型检查的效果
而且dynamic_cast要求有虚函数,否则编译不通过。
(2)dynamic_cast转换如果成功的话返回的是指向类的指针或引用
例如:
①如果是子类转父类,必须得有虚函数才可以进行转换
②如果是父类转子类,父类中虚函数可有可无都可以进行转换
四、const_cast: 去掉const属性,将常量转换成非常量,但不会破坏原常量的const属性,只是返回的结果是变量。
例如:
1.常量指针转换成非常量指针,转换后的指针地址不变
2.常量引用转换成非常量引用
3.常量对象(或基本类型)不可以被转换成非常量对象(或基本类型)