C++unique_ptr单独声明和实例化
C++ unique_ptr separate declaration and instantiation
也许这是一个非常简单的问题。但作为一名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()
。我有两个问题:
- 在这种情况下,我需要使用指针吗
- 如何使用
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
,即使很难做到。你说你需要阅读一些配置才能获得valueA
和valueB
。您可以调用一个私有静态函数来读取配置,然后将读取的值传递给另一个构造函数。
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);
相关文章:
- 单行类声明和实例化
- 从模板基类派生是否在派生类声明的点实例化模板
- 在实例化封闭类模板之后,我们可以声明模板类成员的部分专用化吗
- 我们可以在没有新实例化的情况下声明一个抽象方法来返回抽象超类中的子类对象吗
- 在不使用默认构造函数的情况下声明 POD 结构时,会实例化什么?
- C++17 单独的显式方法模板实例化声明和定义
- 声明基类类型的指针,但随后通过指向子类来实例化它.这是良好的编程实践吗?
- 模板函数是否以内联方式声明 constexpr,即使实例化不是 constexpr
- C 在对象实例化时如何分开声明和构造函数
- 无法在好友函数中实例化类?我没有得到在范围错误中声明
- 仅标头模板(外部模板)的显式实例化声明
- 声明无法解决"实例化后的显式专用化"错误
- gcc 中的模板显式实例化(定义和声明)
- 类模板实例化错误:未在此范围内声明类型
- 未在此作用域中声明实例化类/的作用域
- 使用显式实例化声明删除反向指针会导致 std::bad_weak_ptr 异常
- 为什么为模板实例化声明运行时多态性会导致链接器错误
- c++ 11:显式实例化声明vs显式实例化定义
- 友元声明和显式模板实例化声明
- 仅针对类的特定模板实例化声明成员函数