Przeciążenie operatora <<: nie można powiązać wartości l z „std :: basic_ostream <char> &&”
Mam klasę, która używa klasy zagnieżdżonej i chce użyć klasy zagnieżdżonejoperator<<
zdefiniowaćoperator<<
w klasie wyższej. Oto jak wygląda mój kod:
#include <memory>
#include <iostream>
template<typename T>
struct classA {
struct classB
{
template<typename U>
friend inline std::ostream& operator<< (std::ostream &out,
const typename classA<U>::classB &b);
};
classB root;
template<typename U>
friend std::ostream& operator<< (std::ostream &out,
const classA<U> &tree);
};
template<typename T>
inline std::ostream& operator<< (std::ostream &out,
const classA<T> &tree)
{
out << tree.root;
return out;
}
template<typename T>
inline std::ostream& operator<< (std::ostream &out,
const typename classA<T>::classB &b)
{
return out;
}
int main()
{
classA<int> a;
std::cout << a;
}
Podczas kompilacji bez wsparcia dla C ++ 11, definicja operatora << dla klasy wewnętrznej wydaje się nie być znaleziona przez kompilator:
so.hpp:24:7: error: no match for ‘operator<<’ in ‘out << tree.classA<int>::root’
so.hpp:24:7: note: candidates are: ...
Z GCC 4.6 i 4.7 podczas kompilacji ze std = c ++ 0x:
so.hpp:21:3: error: cannot bind ‘std::ostream {aka std::basic_ostream<char>}’ lvalue to ‘std::basic_ostream<char>&&’
In file included from /usr/include/c++/4.7/iostream:40:0,
from so.hpp:2:
/usr/include/c++/4.7/ostream:600:5: error: initializing argument 1 of ‘std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&&, const _Tp&) [with _CharT = char; _Traits = std::char_traits<char>; _Tp = classA<int>::classB]’
Czy ktoś może mi powiedzieć, dlaczego ten kod nie jest legalny i jaki jest najlepszy sposób na zrobienie tego, co chcę?