Herb Sutter在此处提出了make_unique()的简单实现:http://herbsutter.com/gotw/_102/

这里是:

template<typename T, typename ...Args>
std::unique_ptr<T> make_unique( Args&& ...args )
{
    return std::unique_ptr<T>( new T( std::forward<Args>(args)... ) );
}

我的问题是可变参数模板尚未成为VS2012的一部分,因此我无法按原样使用此代码。

在VS2012中有没有一种可维护的方式来编写此代码,而不会涉及将具有不同args计数的同一函数复制粘贴?

最佳答案

您可以使用Boost.Preprocessor生成不同的参数计数,但是我真的看不到这样做的好处。只需完成一次艰苦的工作,将其填充到标题中即可完成。您可以节省编译时间,并拥有make_unique

Here是我的make_unique.h header 的复制粘贴,可模拟最多5个参数的可变参数模板。

由于OP似乎不喜欢复制粘贴工作,因此下面是生成以上代码的Boost.Preprocessor代码:

首先,制作一个包含模板头多次的主头(从this answer明显盗窃的Boost.Preprocessor迭代代码):

// make_unique.h
#include <memory>
#include <utility>
#include <boost/preprocessor.hpp>

#ifndef MAKE_UNIQUE_NUM_ARGS
// allow this to be changed to a higher number if needed,
// ten is a good default number
#define MAKE_UNIQUE_NUM_ARGS 10
#endif

#if MAKE_UNIQUE_NUM_ARGS < 0
// but don't be stupid with it
#error Invalid MAKE_UNIQUE_NUM_ARGS value.
#endif

/* optional, see above for premade version
// include premade functions, to avoid the costly iteration
#include "detail/blah_premade.hpp

// generate classes if needed
#if MAKE_UNIQUE_NUM_ARGS > MAKE_UNIQUE_NUM_PREMADE
*/
#define BOOST_PP_ITERATION_LIMITS (0, MAKE_UNIQUE_NUM_ARGS)
#define BOOST_PP_FILENAME_1 "make_unique_template.h"
#include BOOST_PP_ITERATE()
//#endif

现在,使模板头文件一次又一次地包含进来,并根据MAKE_UNIQUE_NUM_ARGS的值进行不同的扩展:
// make_unique_template.h
// note: no include guard

#define N BOOST_PP_ITERATION()

#define MAKE_UNIQUE_TEMPLATE_PARMS \
  BOOST_PP_ENUM_PARAMS(N, typename A)

#define MAKE_UNIQUE_FUNCTION_PARM(J,I,D) \
  BOOST_PP_CAT(A,I)&& BOOST_PP_CAT(a,I)

#define MAKE_UNIQUE_FUNCTION_PARMS \
  BOOST_PP_ENUM(N, MAKE_UNIQUE_FUNCTION_PARM, BOOST_PP_EMPTY)

#define MAKE_UNIQUE_ARG(J,I,D) \
  std::forward<BOOST_PP_CAT(A,I)>(BOOST_PP_CAT(a,I))

#define MAKE_UNIQUE_ARGS \
  BOOST_PP_ENUM(N, MAKE_UNIQUE_ARG, BOOST_PP_EMPTY)

template<class T BOOST_PP_COMMA_IF(N) MAKE_UNIQUE_TEMPLATE_PARMS>
std::unique_ptr<T> make_unique(MAKE_UNIQUE_FUNCTION_PARMS){
  return std::unique_ptr<T>(new T(MAKE_UNIQUE_ARGS));
}

// clean up
#undef MAKE_UNIQUE_TEMPLATE_PARMS
#undef MAKE_UNIQUE_FUNCTION_PARM
#undef MAKE_UNIQUE_FUNCTION_PARMS
#undef MAKE_UNIQUE_ARG
#undef MAKE_UNIQUE_ARGS
#undef N

关于c++ - 有没有一种方法可以在VS2012中编写make_unique()?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/12547983/

10-11 05:59