C++ 智能指针类型转换测试

这个是 GPT 回答的,可以运行。

#include <iostream>
#include <memory>

class Base {
public:
    virtual void show() const {
        std::cout << "Base class" << std::endl;
    }
    virtual ~Base() = default; // 确保基类有虚析构函数
};

class Derived : public Base {
public:
    void show() const override {
        std::cout << "Derived class" << std::endl;
    }
};

#if false  // shared_ptr

int main() {
    // 创建一个 Derived 类的 shared_ptr
    std::shared_ptr<Derived> derivedPtr = std::make_shared<Derived>();

    // 上行转换:从派生类指针转换为基类指针
    std::shared_ptr<Base> basePtr = derivedPtr;
    basePtr->show(); // 输出 "Derived class"

    // 动态转换:从基类指针转换为派生类指针
    std::shared_ptr<Derived> derivedPtr2 = std::dynamic_pointer_cast<Derived>(basePtr);
    if (derivedPtr2) { // 如果转换成功
        derivedPtr2->show(); // 输出 "Derived class"
    }
    else {
        std::cout << "dynamic_pointer_cast 失败" << std::endl;
    }

    return 0;
}

#endif

#if true 

int main() {
    // 创建一个 Derived 类的 unique_ptr
    std::unique_ptr<Derived> derivedPtr = std::make_unique<Derived>();

    // 上行转换:从派生类指针转换为基类指针
    std::unique_ptr<Base> basePtr = std::move(derivedPtr);
    basePtr->show(); // 输出 "Derived class"

    // 自己新增测试 上面失去控制权之后,这里为 null,会进入 else
    // 不要使用失去控制权的指针对象   编译器一般也会有警告
    if (derivedPtr)  
        derivedPtr->show();
    else
        std::cout << "拾取控制权,为 null。" << std::endl;

    // 动态转换需要手动进行,因为 unique_ptr 不直接支持 dynamic_pointer_cast
    // 但可以通过 raw pointer 实现
    Derived* rawPtr = dynamic_cast<Derived*>(basePtr.get());
    if (rawPtr) {
        rawPtr->show(); // 输出 "Derived class"
    }
    else {
        std::cout << "dynamic_cast 失败" << std::endl;
    }

    return 0;
}

#endif

输出:

Derived class
拾取控制权,为 nullDerived class

// unique_ptr 可以通过 release() 释放所有权


#if true

int main() {
    // 创建一个 Derived 类的 unique_ptr
    std::unique_ptr<Derived> derivedPtr = std::make_unique<Derived>();

    // 上行转换:从派生类指针转换为基类指针
    //std::unique_ptr<Base> basePtr = std::move(derivedPtr);
    std::unique_ptr<Base> basePtr(derivedPtr.release());
    basePtr->show(); // 输出 "Derived class"

    // 自己新增测试 上面失去控制权之后,这里为 null,会进入 else
    // 不要使用失去控制权的指针对象   编译器一般也会有警告
    if (derivedPtr)
        derivedPtr->show();
    else
        std::cout << "拾取控制权,为 null。" << std::endl;

    // 动态转换需要手动进行,因为 unique_ptr 不直接支持 dynamic_pointer_cast
    // 但可以通过 raw pointer 实现
    //Derived* rawPtr = dynamic_cast<Derived*>(basePtr.get());
    derivedPtr.reset(dynamic_cast<Derived*>(basePtr.release()));
    if (derivedPtr)
    {
        derivedPtr->show();
    }

    //if (rawPtr) {
    //    rawPtr->show(); // 输出 "Derived class"
    //}
    else {
        std::cout << "dynamic_cast 失败" << std::endl;
    }

    system("pause");
    return 0;
}
posted @   double64  阅读(31)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2022-07-17 C++ 11 原样字符串 R"()"
点击右上角即可分享
微信分享提示