У меня есть класс A
(из библиотеки, над которой у меня нет контроля) с помощью частного конструктора копирования и метода clone
, а также производного класса B
от A
. Я хотел бы реализовать clone
для B
.конструктор копирования неявно удаляется, потому что определение по умолчанию будет плохо сформировано
Наивный подход
#include <memory>
class A { // I have no control here
public:
A(int a) {};
std::shared_ptr<A>
clone() const
{
return std::shared_ptr<A>(new A(*this));
}
private:
A(const A & a) {};
};
class B: public A {
public:
B(int data, int extraData):
A(data),
extraData_(extraData)
{
}
std::shared_ptr<B>
clone() const
{
return std::shared_ptr<B>(new B(*this));
}
private:
int extraData_;
};
int main() {
A a(1);
}
однако, не удается, так как конструктор копирования из A
является частным:
main.cpp: In member function ‘std::shared_ptr<B> B::clone() const’:
main.cpp:27:42: error: use of deleted function ‘B::B(const B&)’
return std::shared_ptr<B>(new B(*this));
^
main.cpp:17:7: note: ‘B::B(const B&)’ is implicitly deleted because the default definition would be ill-formed:
class B: public A {
^
main.cpp:14:5: error: ‘A::A(const A&)’ is private
A(const A & a) {};
^
main.cpp:17:7: error: within this context
class B: public A {
Там может способ использовать A::clone()
для B::clone()
, но я не знаю, как это будет работать. Любые намеки?
У меня нет контроля над 'A', поскольку он исходит из библиотеки; Я разъяснил это в оригинальной публикации. –
Тогда вам не следует выводить из 'A'. – Peter
@ NicoSchlömer: Ох .. в этом случае это плохая идея, чтобы получить от 'A'. Теперь вы должны использовать композицию вместо наследования. – Nawaz