4

我有这个函数应该生成不同的派生对象并返回为unique_ptr<base>

class base {};  // contains pure functions.
class derived1 {}; // reifies that pure iface.
class derived2 {}; // reifies that pure iface.

unique_ptr<base> factory::load(int param)
  {
    switch (param)
      {
      case PARAM_MAIN:
        return new derived1();
        // return std::move(new derived1());

      case PARAM_2:
        return new derived2();

      case ...:
        return new derived...();

      }
  }

即使使用 std::move,我也无法让这件事继续下去。(也使用了dynamic_cast,但可能做错了)。

这是我得到的错误:(ArchLinux 上的 gcc (GCC) 4.8.1 20130725 (prerelease))

could not convert '(std::shared_ptr<base::model>((*(const std::shared_ptr<base::model>*)(& associatedModel))), (operator new(48ul), (<statement>, ((derived1*)<anonymous>))))' from 'derived1*' to 'std::unique_ptr<base>'
            associatedModel));

我希望我已经清楚我想做什么。

我该怎么做?谢谢。

4

2 回答 2

6

您可以使用std::make_uniqueunique_ptr<derived1>(new derived1());做甚至更好(使用 C++14)。

using namespace std;

class base {};  // contains pure functions.
class derived1 {}; // reifies that pure iface.
class derived2 {}; // reifies that pure iface.

unique_ptr<base> factory::load(int param) {
  switch (param) {
    case PARAM_MAIN: return make_unique<derived1>();
    case PARAM_2:    return make_unique<derived2>();
    case ...:        return make_unique<derived...>();
  }
}
于 2015-04-04T10:03:16.740 回答
-7

我是这样解决的:

return unique_ptr<base>(dynamic_cast<base*>(std::move(
               new derived1()
       )));

所以关键是它必须base在它仍然是原始的时候被向上转换,然后才被包裹在unique_ptr.

无论如何,我很欣赏更简单的答案。尤其是那些基于 unique_ptr 内部和实现的推理。

于 2013-08-17T12:17:09.487 回答