Il y a eu quelques publications à ce sujet, mais je pense que c'est l'un des exemples les plus simples, et j'espère que cela éclaircira certaines choses à propos de cout et de l'initialisation.impossible de lier 'std :: ostream {aka std :: basic_ostream <char>}' lvalue à 'std :: basic_ostream <char> &&'
ceci marche:
class A {
public:
std::ostream& operator<< (std::ostream& os) {
return os;
}
};
class B {
std::ostream& operator<< (std::ostream& os) {
A a(); // <-- LOOK
std::cout << a;
return os;
}
};
Mais si je simplement A a()
-A a
:
class A {
public:
std::ostream& operator<< (std::ostream& os) {
return os;
}
};
class B {
std::ostream& operator<< (std::ostream& os) {
A a; // <-- LOOK
std::cout << a;
return os;
}
};
Il lance:
nvcc main.cpp util.cpp -o main -lcublas -std=c++11
In file included from main.cpp:9:0:
cout-test.hpp: In member function ‘std::ostream& B::operator<<(std::ostream&)’:
cout-test.hpp:21:20: error: cannot bind ‘std::ostream {aka std::basic_ostream<char>}’ lvalue to ‘std::basic_ostream<char>&&’
std::cout << a;
^
In file included from /usr/include/c++/4.8/iostream:39:0,
from main.cpp:5:
/usr/include/c++/4.8/ostream:602: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 = A]’
operator<<(basic_ostream<_CharT, _Traits>&& __os, const _Tp& __x)
^
make: *** [main] Error 1
je reçois la même erreur si je fais A a
une Classe:
class B {
A a; // <-- LOOK
std::ostream& operator<< (std::ostream& os) {
std::cout << a;
return os;
}
};
Ce qui donne?
'std :: cout << a' *** n'appelle pas *** la fonction membre' operator << '. Et la seule raison pour laquelle le premier code compile est parce que c'est [une analyse plus vexante] (https://en.wikipedia.org/wiki/Most_vexing_parse). –
Super à savoir! Pouvez-vous s'il vous plaît expliquer un peu plus? – ethanabrooks