33

我的编译器不支持 make_unique。一个怎么写?

template< class T, class... Args > unique_ptr<T> make_unique( Args&&... args );
4

2 回答 2

50

Stephan T. Lavavej(也被 STL 知道)的版本,他最初提议将此函数添加到 C++14

#include <cstddef>
#include <memory>
#include <type_traits>
#include <utility>

namespace std {
    template<class T> struct _Unique_if {
        typedef unique_ptr<T> _Single_object;
    };

    template<class T> struct _Unique_if<T[]> {
        typedef unique_ptr<T[]> _Unknown_bound;
    };

    template<class T, size_t N> struct _Unique_if<T[N]> {
        typedef void _Known_bound;
    };

    template<class T, class... Args>
        typename _Unique_if<T>::_Single_object
        make_unique(Args&&... args) {
            return unique_ptr<T>(new T(std::forward<Args>(args)...));
        }

    template<class T>
        typename _Unique_if<T>::_Unknown_bound
        make_unique(size_t n) {
            typedef typename remove_extent<T>::type U;
            return unique_ptr<T>(new U[n]());
        }

    template<class T, class... Args>
        typename _Unique_if<T>::_Known_bound
        make_unique(Args&&...) = delete;
}

编辑:将代码更新为N3656标准修订版

于 2013-07-27T21:03:15.377 回答
48

复制自make_unique 和完美转发( Herb Sutter 的博客中给出的相同)

template<typename T, typename... Args>
std::unique_ptr<T> make_unique(Args&&... args)
{
    return std::unique_ptr<T>(new T(std::forward<Args>(args)...));
}

如果您在 VC2012 中需要它,请参阅Is there a way to write make_unique() in VS2012?


不过,如果sasha.sochka 的答案中的解决方案与您的编译器一起编译,我会选择那个。这更精细,也适用于数组。

于 2013-07-27T22:48:27.190 回答