初始化的boost ::可选的不可复制的对象(init boost::optional of non

2019-09-03 06:16发布

我应该怎么做初始化boost::optional< T >如果基础类型T的非缺省构造的,不可复制/移动的,但一个人的情况下仍然可以存在?

难道是禁止boost::optional任何语义的原因有像一些成员函数template< typename... Args > boost::optional< T >::construct(Args && ...args) ,它提供所有参数到就地operator new完全构造对象(对于非ref类型T )? 变型是有像非成员函数std::make_shared< T >

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

Answer 1:

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);
...

在C ++ 14有一个建议std::make_optional这将是一个更好的解决这个问题。 然而,这并没有在Boost.Optional实施。



文章来源: init boost::optional of non-copyable object