假设我有两个类,Base和Derived,它们有一个变量来判断对象是否为Derived类型
class Base {
public:
Base() : is_derived(false) {}
bool is_derived;
};
class Derived : public Base {
public:
Derived() : is_derived(true) {}
int derived_only_member;
};我有一个std::shared_ptr to Base对象的std::set:
std::set<std::shared_ptr<Base> > bases;
// Populate this set one way or another我需要遍历该集合,并仅将Derived对象复制到另一组类似的Base共享指针中:
std::set<std::shared_ptr<Base> > copies;
for(auto &b: bases) {
if(b->is_derived) {
copies.insert(/*Somehow copy the `Derived` object and assign a `std::shared_ptr<Base>` to it */);
}
}如果我知道Base指针指向一个Derived对象,我如何复制它以使副本具有相同的derived_only_member值?
有没有办法在没有复制构造函数的情况下做到这一点,复制构造函数为Derived有而Base没有的每个成员变量都有一个参数?我的真实版本的Derived有很多成员,所以这是不切实际的。
发布于 2017-07-19 02:52:03
有没有一种方法可以做到这一点,而不是复制构造函数,它为
Derived的每个成员变量都有一个参数,而Base没有?
复制构造函数不需要每个成员变量都有参数。编译器也已经为您生成了一个。
你需要的是一个造型:
std::set<std::shared_ptr<Base> > copies;
for(auto &b: bases) {
if(b->is_derived) {
copies.insert(std::make_shared<Derived>(static_cast<Derived>(*b)));
// ^^^^^^^^^^^^^^^^^^^^^ ^
}
}注意:
您甚至不需要is_derived成员来检查从Base派生的实例。您可以改用dynamic_cast:
std::set<std::shared_ptr<Base> > copies;
for(auto &b: bases) {
Derived* org = dynamic_cast<Derived*>(b.get());
if(org) {
copies.insert(std::make_shared<Derived>(*org));
}
}https://stackoverflow.com/questions/45174747
复制相似问题