В 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
.
Как вы можете видеть, это скоро станет уродливым, так что вам будет лучше, если вы сможете использовать вариационную версию шаблона.