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 );
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.
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