давайте рассмотрим этот код, чтобы реализовать оператор < < для двух классов:оператора перегрузки << для шаблона класса
#include <iostream>
using std::cout;
using std::endl;
class A
{
int a1_;
public:
A(int a1) : a1_(a1){}
std::ostream& print(std::ostream& os) const
{
return os << "a1_ : " << a1_ << endl;
}
};
class B
{
int b1_;
double b2_;
public:
B(int b1,double b2) : b1_(b1),b2_(b2){}
std::ostream& print(std::ostream& os) const
{
os << "b1_ : " << b1_ << endl;
os << "b2_ : " << b2_ << endl;
return os;
}
};
std::ostream& operator<<(std::ostream& os, const A& in)
{
return in.print(os);
}
std::ostream& operator<<(std::ostream& os, const B& in)
{
return in.print(os);
}
int main(int argc,char* argv[])
{
A myA(10);
B myB(20,30.14);
cout << myA << myB << endl;
return 0;
}
Потому что я ленивый, я хотел бы представить версию шаблона оператора < < вместо две версии, как указано выше. Я могу легко его заменить:
template< class T>
std::ostream& operator<<(std::ostream& os, const T& in)
{
return in.print(os);
}
Пока все хорошо. Если у меня есть несколько классов, я могу реализовать оператор < < за один раз. Проблема начинается, когда один из моих классов является шаблоном класса. Давайте рассмотрим предыдущий пример, но с шаблоном класса B:
#include <iostream>
using std::cout;
using std::endl;
class A
{
int a1_;
public:
A(int a1) : a1_(a1){}
std::ostream& print(std::ostream& os) const
{
return os << "a1_ : " << a1_ << endl;
}
};
template <class T>
class B
{
int b1_;
T b2_;
public:
B(int b1,T b2) : b1_(b1),b2_(b2){}
std::ostream& print(std::ostream& os) const
{
os << "b1_ : " << b1_ << endl;
os << "b2_ : " << b2_ << endl;
return os;
}
};
std::ostream& operator<<(std::ostream& os, const A& in)
{
return in.print(os);
}
template <class T>
std::ostream& operator<<(std::ostream& os, const B<T>& in)
{
return in.print(os);
}
int main(int argc,char* argv[])
{
A myA(10);
B<A> myB(20,myA);
cout << myA << myB << endl;
return 0;
}
Эта версия работает и у меня есть ожидаемый результат, однако я предоставил два оператора < < функции (по одному для каждого класса), давайте представим, что у меня есть 200 классы, которые уже реализуют публичную версию & print (ostream & os) const. Некоторые из них - это класс шаблонов (с несколькими параметрами).
Как я могу написать версию шаблона оператора < < в этом сценарии?
Спасибо вам за помощь.
Ваш первый код также работает для шаблонов классов. Однако будьте осторожны, что он будет работать для * всех * классов, которые не определяют собственный 'operator <<', и это, вероятно, нежелательно. В частности, такая функция уже определена где-то в стандартной библиотеке, и вы обязаны нарушать одно правило определения с помощью вашего определения. –
@ Konrad: Что ты имеешь в виду? Это никогда не должно быть причиной ошибки «no operator << для XXX»? – UncleBens
@ Konrad: разве это не лучшее совпадение, если оно определено для определенного класса? –