在C++ 0x你有template typedef
终于可用!
免责声明:什么也没有编...
维基百科的文章:
template< typename second>
using TypedefName = SomeType<OtherType, second, 5>;
而你的情况会产生
template <class Type>
using vector3 = vector<Type, 3>;
我不能告诉你如何很多我渴望这个;)
但它不能解决参数问题。如前所述,你可以尝试在这里使用可变参数模板,但是我不确定在这种情况下它们的应用。正常的使用是递归方法,你需要在中间放一个static_assert
。
编辑考虑到意见。
template <class Type, size_t Size>
class vector
{
public:
template <class... Args>
vector(Args... args): data({args...})
{
// Necessary only if you wish to ensure that the exact number of args
// is passed, otherwise there could be less than requested
BOOST_MPL_ASSERT_RELATION(sizeof...(Args), ==, Size);
}
private:
T data[Size];
};
已有的另一种可能性是将预处理器生成与boost::enable_if
相结合。
template <class Type, size_t Size>
class vector
{
public:
vector(Type a0, typename boost::enable_if_c< Size == 1 >::type* = 0);
vector(Type a0, Type a1, typename boost::enable_if_c< Size == 2 >::type* = 0);
// ...
};
使用Boost.Preprocessor进行生成使得这更容易。
BOOST_PP_REPEAT(MAX_COUNT, CONSTRUCTOR_MACRO, ~);
// where MAX_COUNT is defined to the maximum size you wish
// and CONSTRUCTOR_MACRO actually generates the constructor
#define CONSTRUCTOR_MACRO(z, n, data) \
vector( \
BOOST_PP_ENUM_PARAMS(n, Type a), \
typename boost::enable_if_c< Size == n >::type* = 0 \
);
构造函数的实现留给读者练习。这是另一个电话BOOST_PP_REPEAT
。正如你所看到的,它很快变得丑陋,所以如果你可以使用可变模板版本,你会变得更好。
sizeof ...(Args)的模板参数个数? – Tomek 2010-07-15 17:25:11
也许,我从来没有需要它,我找不到任何参考... – 2010-07-15 17:35:33
通过使用初始化程序列表:'data({args ...})'摆脱您的'init'函数 – phlipsy 2010-07-15 20:06:22