Подтвердить что ты не робот

Как реализовать функцию make_unique в С++ 11?

Мой компилятор не поддерживает make_unique. Как написать?

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

Ответ 1

Скопировано из 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, см. Есть ли способ написать make_unique() в VS2012?


Тем не менее, если решение в sasha.sochka answer компилируется с вашим компилятором, я бы пошел с этим. Это более сложное и работает с массивами.

Ответ 2

Версия Stephan T. Lavavej (также известная STL), которая первоначально предлагала добавить эту функцию в С++ 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;
}

EDIT: обновленный код до N3656 стандартная версия