Как реализовать функцию make_unique в С++ 11? Мой компилятор не поддерживает make_unique. Как написать? template< class T, class... Args > unique_ptr<T> make_unique( Args&&... args ); Ответ 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 стандартная версия
Ответ 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 стандартная версия