加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – “dynamic_cast”从Base到Derived

发布时间:2020-12-16 05:38:29 所属栏目:百科 来源:网络整理
导读:是的,我知道如果Base不是多态的,那么使用dynamic_cast的downcast无法编译,但是我的问题不在此. class Base { public: virtual void bar() { cout "barn"; }};class Derived: public Base { public: void foo() { cout "foon"; }};int main(){ Base *pb; De
是的,我知道如果Base不是多态的,那么使用dynamic_cast的downcast无法编译,但是我的问题不在此.
class Base {
    public:
        virtual void bar()
        {
            cout << "barn";
        }
};

class Derived: public Base {
    public:
        void foo()
        {
            cout << "foon";
        }
};

int main()
{
    Base *pb;
    Derived *pd;

    pb = new Derived;  //Base* points to a Derived object
    pd = dynamic_cast<Derived*>(pb); 
    pd->foo();  //outputs foo

    pb = new Base;  //Base* points to a Base object
    pd = dynamic_cast<Derived*>(pb);  
    pd->foo();  //outputs foo,too. Why?
}

我以为当pb = new Derived; pb实际上指向一个Derived对象位于堆中.在pd = dynamic_cast< Derived *>(pb)之后,pd也指向Derived对象,所以pd-> foo()应该是OK的.

但是当pb = new Base时,pb指向的是一个Base对象,然后在pd = dynamic_cast< Derived *>(pb); pd-> foo()如何工作? dynamic_cast是否将堆中的Base对象转换成Derived对象?

解决方法

在C中,类的每个实例都有自己的数据类型,但所有类在内存中共享相同的功能(除内联函数之外).在你的情况下,当你说:
pd->foo();

您本质上是调用Derived :: foo,它是内存中的一个函数,编译器知道它在哪里.事情是,它根本不依赖于pd.但是,如果你有这样的话:

class Derived : public Base {
    private:
        int a;

    public:
        Derived() { a = 100; }

        void foo() {
            std::cout<<a<<std::endl;
        }
 };

然后,pd-> foo()将导致分段故障.在这里,您的动态转换失败,当Derived :: foo被调用时,它将作为该对象传递0.在以前的情况下是好的,因为这个对象从来没有被使用过.然而,在第二种情况下,它被使用,因此导致分段故障.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读