c – 为什么ostream_iterator不按预期工作?

不用说以下代码
#include <utility>
#include <vector>
#include <iostream>
#include <iterator>

using namespace std;

typedef pair<char,char> PAIR;

ostream& operator <<(ostream& os,const PAIR& r)
{
    return os << r.first;
}

int main() 
{
    vector<PAIR> coll; 

    cout << coll[0]; // OK. 

    // The following line will cause a compilation error! Why???
    copy(coll.begin(),coll.end(),ostream_iterator<PAIR>(cout)); 
}

解决方法

问题是名称查找找不到您的运算符<(ostream& os,const PAIR& r).尝试调用运算符的代码<<在ostream_iterator<>内的某处它本身就在std命名空间内.名称查找在ostream_iterator<>内部查找正确的函数和std命名空间;参数相关查找在这里无助于此,因为这两个参数也在std命名空间中.

所以,我的建议是(1)将你的运算符包装到命名空间std {}中,但是UB,IIRC.或者(2)创建一个从std :: pair继承的结构,在命名空间中定义一个新类型,并使用ADL找到你的运算符<(). 更新: 我的第三个建议是使用自定义的操纵器打印出来. 对于我的第二个建议,如果你可以使用C 11,继承自std :: pair应该很容易(未经测试):

struct PAIR : std::pair
{
  using std::pair::pair;
};

如果您不能使用C 11,那么我建议使用自定义的操纵器.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...