33

私のコンパイラは make_unique をサポートしていません。どのように書くのですか?

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

2 に答える 2

50

この関数を C++14 に追加することを最初に提案した Stephan T. Lavavej (STL とも呼ばれる) によるバージョン

#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's blogに記載されています)

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 に答える