web-dev-qa-db-fra.com

Comment implémenter la fonction make_unique en C ++ 11?

Mon compilateur ne prend pas en charge make_unique. Comment en écrire un?

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

Copié de make_unique et transfert parfait (la même chose est donnée dans le blog de 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)...));
}

Si vous en avez besoin dans VC2012, voir Existe-t-il un moyen d'écrire make_unique () dans VS2012?


Néanmoins, si la solution dans la réponse de sasha.sochka se compile avec votre compilateur, j'irais avec celle-là. C'est plus élaboré et fonctionne également avec les tableaux.

30
Ali

Version de Stephan T. Lavavej (également connu par STL) qui a initialement proposé d'ajouter cette fonction au 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;
}

EDIT: code mis à jour vers la révision standard N3656

44
sasha.sochka