init boost::可选的不可复制对象

init boost::可选的不可复制对象,boost,default-constructor,noncopyable,boost-optional,Boost,Default Constructor,Noncopyable,Boost Optional,如果基础类型T是非默认可构造、不可复制/可移动的,但实例仍然可以存在,那么我应该如何初始化boost::optional 出于任何语义原因,boost::optional是否禁止使用一些成员函数,如templateboost::可选的::构造(Args&&…Args),将所有参数传递到就地操作符new,以完全构造对象(对于非引用类型T)?变量是具有非成员函数,如std::make_shared 在我看来,我的问题可以通过使用std::unique_ptr/std::shared_ptr来解决,但

如果基础类型
T
是非默认可构造、不可复制/可移动的,但实例仍然可以存在,那么我应该如何初始化
boost::optional

出于任何语义原因,
boost::optional
是否禁止使用一些成员函数,如
templateboost::可选的::构造(Args&&…Args)
,将所有参数传递到就地
操作符new
,以完全构造对象(对于非引用类型
T
)?变量是具有非成员函数,如
std::make_shared


在我看来,我的问题可以通过使用
std::unique_ptr
/
std::shared_ptr
来解决,但在这种情况下,我的问题是:“为什么
boost::optional
进度被冻结?”。

boost::optional
可以使用不可复制的类型初始化

具体来说,您可以这样使用它们:

#include <boost/optional.hpp>
#include <boost/utility/in_place_factory.hpp>

class MyType : private boost::noncopyable
{ 
public:
  MyType(T1 const& arg1, T2 const& arg2);
}
...
boost::optional<MyType> m_var;
...
m_var = boost::in_place(arg1, arg2);
...
#包括
#包括
类MyType:private boost::不可复制
{ 
公众:
MyType(T1常量和arg1,T2常量和arg2);
}
...
boost::可选的m_变量;
...
m_var=boost::in_place(arg1,arg2);
...

在C++14中,提出了一种更好的解决方案。但是,Boost.Optional中没有实现这一点。

如果它是默认可构造的,该怎么办?有没有一种方法可以构造一个不可复制的boost::optional而不使用boost::in_place?如果它是一个默认的可构造调用boost::in_place而没有参数,我的各种尝试都失败了:Foo Foo;foo=boost::in_place();