oop — 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 — нет?

-2

Решение

Вы удаляете объект и затем продолжаете получать к нему доступ. Это вызывает неопределенное поведение, что означает, что все может случиться.

Вы можете исправить код, удалив строку delete cobj;, Однако вы должны также проверить, что результат dynamic_cast не является нулевым, прежде чем разыменовывать его.

В случае, если неясно, delete выражение удаляет объект, на который указывает. Не существует такого понятия, как «удалить указатель».

1

Другие решения

Ваша проблема не имеет ничего общего с наследованием или параметрами функции. Проблемный код может быть уменьшен до:

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

Последние две строки — это проблема. delete cobj разрушает объект, но cobj->GetValue() все еще пытается использовать это. Этот код имеет неопределенное поведение.

Чтобы исправить код, вам нужно удалить либо delete cobj или GetValue() вызов. В любом случае, не пытайтесь использовать объект после того, как он был уничтожен.

1

По вопросам рекламы [email protected]