Как реализовать дополнительные параметры шаблона?Как реализовать дополнительные параметры шаблона?
Я хотел бы иметь класс MyStruct<T1,T2,T3>
, где разрешено использовать только первый или два первых параметра. Теперь функции, которые обрабатывают MyStruct<T1,T2,T3>
, также должны корректно обрабатывать неиспользуемые параметры шаблона.
Пример:
#include <iostream>
template<class T1, class T2, class T3>
struct MyStruct {
T1 t1; T2 t2; T3 t3;
MyStruct() {}
MyStruct(T1 const& t1_, T2 const& t2_, T3 const& t3_)
: t1(t1_), t2(t2_), t3(t3_) {}
};
template<class T1, class T2, class T3>
MyStruct<T1, T2, T3> myplus(MyStruct<T1, T2, T3> const& x,
MyStruct<T1, T2, T3> const& y) {
return MyStruct<T1, T2, T3>(x.t1 + y.t1, x.t2 + y.t2, x.t3 + y.t3);
}
int main() {
typedef MyStruct<int, double, std::string> Struct;
Struct x(2, 5.6, "bar");
Struct y(6, 4.1, "foo");
Struct result = myplus(x, y);
// (8, 9.7, "barfoo")
std::cout << result.t1 << "," << result.t2 << "," << result.t3;
}
Теперь я хотел бы изменить код так, что выше main()
функция все еще работает, но следующий будет работать:
typedef MyStruct<std::string, int> Struct;
// result: ("barfoo", 5)
Struct result = myplus(Struct("bar", 2), Struct("foo", 3));
Или это:
typedef MyStruct<int> Struct;
// result: (5)
Struct result = myplus(Struct(2), Struct(3));
Думаю, boost::tuple
использует подобный трюк, где вы можете использовать boost::tuple<A>
, boost::tuple<A,B>
, boost::tuple<A,B,C>
, но я не уверен, как они это делают.
Я вижу, и функция 'plus()' будет работать, если я определяю 'operator + (Default const & Default const &)', который возвращает простой 'Default()'. Ницца. – Frank