C++unique_ptr单独声明和实例化

C++ unique_ptr separate declaration and instantiation

本文关键字:实例化 声明 单独 ptr C++unique      更新时间:2023-10-16

也许这是一个非常简单的问题。但作为一名Java程序员,我仍在研究如何在C++中正确地实例化对象。我的类中有一个成员变量,我无法在类构造函数的实例化列表中实例化它(因为它取决于一些共构值):

class SomeClass{    
  private:
  ObjectType mObject; //declaration and instantiation??
  public: 
  SomeClass()/*:mObject(valueA,valueB)*/{ 
     //read config here...
     //now we got valueA and valueB
     mObject = mObject(valueA,valueB);
  }    
};

上面显示的代码不起作用,因为C++甚至在到达mObject(valueA, valueB)之前就试图调用mObject()。我有两个问题:

  1. 在这种情况下,我需要使用指针吗
  2. 如何使用unique_ptr?我已经搜索了一些例子,但没有找到一个单独声明和实例化的例子。(就像这里)

如果我尝试像这样使用unique_ptr,我会遇到一个错误:

 #include <memory>
  class SomeClass{    
      private:
      std::unique_ptr<ObjectType> mObject;
      public: 
      SomeClass(){ 
         //read config here...
         //now we got valueA and valueB
         mObject = new ObjectType(valueA,valueB);
      }    
    };

错误为:

错误:"operator="不匹配(操作数类型为"std::unique_ptr"answers"ObjectType*")mObject=新的ObjectType(valueA,valueB)

也许还有更好的解决方案,但我还没有看到。

您可以设置unique_pointer的值,如下所示:

mObject.reset(new ObjectType(valueA,valueB));

查看此处的文档:http://www.cplusplus.com/reference/memory/unique_ptr/reset/

你真的应该尝试在构造函数初始化器列表中正确初始化mObject,即使很难做到。你说你需要阅读一些配置才能获得valueAvalueB。您可以调用一个私有静态函数来读取配置,然后将读取的值传递给另一个构造函数。

private:
static std::pair<A, B> readConfig();
SomeClass(std::pair<A, B> p) : mObject(p.first, p.second) {}
public:
SomeClass() : SomeClass(readConfig()) {}

这样做有很多优点,例如:

  • 您肯定知道ObjectType对象的寿命与SomeClass对象的寿命一样长;不可能在早些时候意外摧毁它
  • 如果SomeClass对象是const,则可以避免意外修改ObjectType对象。std::unique_ptr成员将具有"浅const"语义

如果你真的想把mObject变成std::unique_ptr,那么有两种方法:

mObject.reset(new ObjectType(valueA, valueB));

mObject = std::make_unique<ObjectType>(valueA, valueB);