首页 > 解决方案 > C++ 将父指针降级为用作函数参数的子指针

问题描述

我想在某些函数中使用子指针代替父参数。这是简化的代码

#include <iostream>
#include <string>
using namespace std;
class Parent
{
    private:
        string value;
    public:
        void SetValue(const string& in){ value = in; }
        const string& GetValue() const { return value; }
        virtual ~Parent() {};
};
class Child : public Parent
{
};
void Func(Parent* obj)
{
    Child* cobj = dynamic_cast<Child*>(obj);
    cobj->SetValue("new value");
    delete cobj;
}
int main(int argc, char** argv)
{
    Child* cobj = new Child();
    Func(cobj);
    cout<<"value: "<<cobj->GetValue();
    return 0;
}

但它返回value:
Func没有设置值属性。如何修复代码?
UPDATE1:
但是使用此代码:

#include <iostream>
#include <string>
using namespace std;
class Parent
{
    private:
        string value;
    public:
        void SetValue(const string& in){ value = in; }
        const string& GetValue() const { return value; }
        virtual ~Parent() {};
};
class Child : public Parent
{
    private:
        int number;
    public:
        void SetNumber(int in){ number = in; }
        int GetNumber() const { return number; }
};
void Func(Parent* obj)
{
    Child* cobj = dynamic_cast<Child*>(obj);
    cobj->SetValue("new value");
    cobj->SetNumber(100);
    delete cobj;
}
int main(int argc, char** argv)
{
    Child* cobj = new Child();
    Func(cobj);
    cout<<"value: "<<cobj->GetValue()<<endl;
    cout<<"number: "<<cobj->GetNumber()<<endl;
    return 0;
}

我得到value: number: 100
为什么 SetNumber 工作但 SetValue 没有?

标签: c++oopdynamic-castdowngrade

解决方案


您的问题与继承或函数参数无关。有问题的代码可以简化为:

Child* cobj = new Child();
cobj->SetValue("new value");
delete cobj;
cobj->GetValue();

最后两行是问题所在。delete cobj销毁对象,但cobj->GetValue()仍尝试使用它。此代码具有未定义的行为。

要修复代码,您需要删除其中一个delete cobjGetValue()调用。在任何情况下,都不要在对象被销毁后尝试使用它。


推荐阅读