Polymorphic copy-constructor with type conversion(具有类型转换的多态复制构造函数)
问题描述
我需要复制构造一个对象,同时将其类型更改为另一个类,该类是同一类层次结构的成员.我已经阅读了多态复制构造函数,并且(希望)理解它背后的想法.然而,我仍然不知道这种模式是否适用于我的情况,如果适用,如何实现它.我认为最好在示例中展示我需要的内容.
I need to copy-construct an object simultaneously changing it's type to another class being a member of the same class-hierarchy. I've read about polymorphic copy-constructors and (hopefully) understand the idea behind it. Yet, I still don't know if this pattern applies to my case and, if so, how to implement it. I think it's best if I show what I need on an example.
有一个 Base
类和两个子类 Child1
和 Child2
.我需要基于 Child1
创建一个 Child2
类型的对象,即.最重要的是,我需要将 p_int
指向的对象从 Child1
复制到 Child2
.我写了一个简单的程序来说明它:
There is a Base
class and two child classes, Child1
and Child2
. I need to create an object of type Child2
basing on Child1
, ie. most of all, I need to copy the object p_int
is pointing to from Child1
to Child2
. I've written a simple program to illustrate it:
#include <iostream>
using namespace std;
class Base {
public:
Base() { p_int = new int; *p_int = 0; }
~Base() { delete p_int; }
virtual Base* clone() const = 0;
void setpInt(int val) { *p_int = val; }
void setInt(int val) { a = val; }
virtual void print() {
cout << "Base: ";
cout << (long)p_int << ":" << *p_int << " " << a << endl;
}
protected:
int* p_int;
int a;
};
class Child1 : public Base {
public:
Child1() {};
Child1(const Child1& child) {
p_int = new int (*child.p_int);
a = child.a + 1;
}
Base* clone() const { return new Child1(*this); }
void print() {
cout << "Child1: ";
cout << (long)p_int << ":" << *p_int << " " << a << endl;
}
};
class Child2 : public Base {
public:
Child2() {};
Child2(const Child2& child) {
p_int = new int (*child.p_int);
a = child.a + 1;
}
Base* clone() const { return new Child2(*this); }
void print() {
cout << "Child2: ";
cout << (long)p_int << ":" << *p_int << " " << a << endl;
}
};
int main() {
Child1* c1 = new Child1();
Child2* c2;
c1->setpInt(4);
c1->print();
c2 = (Child2*)c1->clone();
c2->print();
}
不幸的是,结果如下,即.没有类型转换:
Unfortunately, the outcome is as below, ie. there is no type conversion:
Child1: 162611224:4 0
Child1: 162611272:4 1
我究竟需要实施什么才能实现我的需要?我开始认为我需要实现一种类型转换机制而不是多态复制构造函数,但我已经很困惑了.
What exactly do I need to implement, to be able to achieve what I need? I'm starting to think there is a type-conversion mechanism I need to implement rather than a polymorphic copy-constructor, but I'm confused already.
要求跟进这里
推荐答案
最简单的解决方案可能是实现一个以 Child1&
作为参数的 Child2
构造函数.然后你可以简单地调用:
Simplest solution would probably be to implement a Child2
constructor taking a Child1&
as parameter. Then you could simply call:
Child2* c2 = new Child2(*c1);
这篇关于具有类型转换的多态复制构造函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:具有类型转换的多态复制构造函数
基础教程推荐
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 如何在 C++ 中处理或避免堆栈溢出 2022-01-01
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- 设计字符串本地化的最佳方法 2022-01-01
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04
- C++,'if' 表达式中的变量声明 2021-01-01
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17
- 运算符重载的基本规则和习语是什么? 2022-10-31