本文将详细介绍dynamic_pointer_cast的用法。 第一步:引入头文件 首先,我们需要引入C++标准库中的<memory>头文件。这个头文件包含了智能指针类template,以及对智能指针的操作。 #include <memory> 第二步:创建原始指针 接下来,我们需要创建一个原始指针,该指针指向需要被智能指针管理的对象。 int* raw_ptr = new ...
dynamic_pointer_cast是C++标准库中的一部分,位于<memory>头文件中,是专门用于智能指针(如std::shared_ptr)的动态类型转换。 检查是否已经正确包含了该库或框架的头文件或命名空间: 确保你的代码中包含了<memory>头文件,并且在使用dynamic_pointer_cast时,已经声明了std命名空间。例如: cpp #include...
std::dynamic_pointer_cast的别名是dynamic_pointer_cast,它是该函数的常用简称。 该函数的作用是将一个指向基类的shared_ptr或weak_ptr对象转换为指向派生类的shared_ptr对象。它会检查指针的动态类型,如果类型匹配,则返回指向派生类的shared_ptr对象;如果类型不匹配,则返回一个空的shared_ptr对象。
1. 如果base_pointer所指向的对象实际上不是DerivedType类型的对象,则dynamic_pointer_cast会返回一个空指针。 2. 如果base_pointer为一个空智能指针,则dynamic_pointer_cast会返回一个空指针。 3. 使用dynamic_pointer_cast时需要包含头文件<memory>。 下面是一个使用dynamic_pointer_cast的例子: class Base { pub...
3、dynamic_pointer_cast当指针是智能指针时候,向下转换,用dynamic_Cast 则编译不能通过,此时需要使用dynamic_pointer_cast。向下转换(含智能指针):struct Father { //基类Father }; struct Son:Father { //基类Father的派生类B }; std::shared_ptr<Father> father; std::shared_ptr<Son> son = std::...
当指针是智能指针时候,向下转换,用dynamic_Cast 则编译不能通过,此时需要使用dynamic_pointer_cast。 向下转换(含智能指针): struct Father { //基类Father }; struct Son:Father { //基类Father的派生类B }; std::shared_ptr<Father> father; std::shared_ptr<Son> son = std::dynamic_pointer_cast<Son>...
spDeriveDown= dynamic_pointer_cast<CDerive>(spBaseDown);if(spDeriveDown == NULL)//由于会进行类型的检查,这边是返回NULLcout <<"spDeriveDown is null"<<endl;/*shared_ptr<CDerive> spDeriveDown; shared_ptr<CBase> spBaseDown; spBaseDown = make_shared<CDerive>(); ...
dynamic_pointer_cast 是 C++ 标准库中的一个函数模板,用于在智能指针之间进行动态类型转换。它接受一个 shared_ptr 或 weak_ptr,并将其转换为另一个类型的 shared_ptr。这种转换只能在具有继承关系的类之间进行。 dynamic_pointer_cast 的语法如下: 代码语言:txt 复制 template<class T, class U> shared_ptr<...
`dynamic_cast` 在运行时检查类型的合法性,如果转换合法,则返回转换后的类型;如果不合法,且用于指针,则返回空指针,用于引用,则抛出 `std::bad_cast` 异常。 二者的主要区别在于它们作用的对象类型: 1. `std::dynamic_pointer_cast` 用于 `std::shared_ptr` 智能指针。 2. `dynamic_cast` 用于原生指针或...
spDeriveDown= dynamic_pointer_cast<CDerive>(spBaseDown);if(spDeriveDown == NULL)//由于会进行类型的检查,这边是返回NULLcout <<"spDeriveDown is null"<<endl; spDeriveDown->myDerive();return0; } 运行结果: 一些结论: 子类向基类转是一定没有问题的。基类转子类的话,必须基类的动态类型与要转换的...