我很抱歉我复制了this question,但我没有评论的声望以及那里没有令人信服的答案。过载后'std :: endl'的'operator <<'不匹配
#include<iostream>
class my_ostream : public std::ostream
{
public:
std::string prefix;
my_ostream():prefix("*"){}
my_ostream& operator<<(const std::string &s){
std::cout << this->prefix << s;
return *this;
}
};
int main(){
my_ostream s;
std::string str("text");
s << str << std::endl;
}
在这里,我得到:
在“s.my_ostream ::运算敌不过 '操作< <' < <(((常量的std :: string &)((常量性病: :字符串*)(& STR))))< <的std :: ENDL”
,我不明白为什么。如果它适用于ostream,它应该适用于my_ostream。这个程序的工作原理:
#include <iostream>
using namespace std;
class a{};
class b:public a{};
class c:public b{};
void f(a){cout << 'a' << endl;}
void f(b){cout << 'b' << endl;}
void f(b, a){cout << "b, a" << endl;}
void f(c){cout << 'c' << endl;}
void f(c, int){cout << "c, int" << endl;}
void f(a*){cout << "pa" << endl;}
void f(b*){cout << "pb" << endl;}
void f(b*, a*){cout << "pb, pa" << endl;}
void f(c*){cout << "pc" << endl;}
void f(c*, int){cout << "pc, int" << endl;}
int main(){
a ao; b bo; c co;
f(ao); f(bo); f(co);
f(co, ao);
a *pa=new(a); b *pb=new(b); c *pc=new(c);
f(pa); f(pb); f(pc);
f(pc, pa);
return 0;}
它输出:
a
b
c
b, a
pa
pb
pc
pb, pa
那么简单超载并不能解释这个错误。另外,我不在这里介绍模板,所以未确定的模板类型参数不应该发挥作用。阅读iostream代码证明是非常困难的,所以我非常感谢任何见解。
事实证明'std :: ostream s;'也不起作用,所以这是相当复杂和难以理解的。 –
互联网说'cout'是'ostream'类型的,但是。任何人都可以解开这个节点? :) –