命名空间中的ostream operator <<隐藏其他ostream :: operator [duplicate]

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了命名空间中的ostream operator <<隐藏其他ostream :: operator [duplicate]相关的知识,希望对你有一定的参考价值。

使用gcc版本5.2.0(GCC)和--std = c ++ 14,如果取消注释名称空间MyNamespace中注释掉的运算符ostream,则以下代码不再编译。这是一个错误还是一个功能? (用g ++编译--c --std = c ++ 14 x.cxx)

#include <string>
#include <iostream>

typedef std::pair<std::string, std::string> StringPair;

std::ostream& operator<<( std::ostream&, const StringPair &pair) {
  std::cout <<pair.first<<"."<<pair.second;
}

namespace MyNamespace {
  class MyClass {};
  //std::ostream& operator<< (std::ostream&, const MyClass &);
  void xxx ();
}

void MyNamespace::xxx () {
  StringPair pair;pair.first="1";pair.second="2";
  std::cout <<pair<<std::endl;
}

我通过运算符<< uncommented获得的错误消息是:

x.cxx: In function ‘void MyNamespace::xxx()’:
x.cxx:18:13: error: no match for ‘operator<<’ (operand types are ‘std::ostream {aka std::basic_ostream<char>}’ and ‘StringPair {aka std::pair<std::__cxx11::basic_string<char>, std::__cxx11::basic_string<char> >}’)
std::cout <<pair<<std::endl;
         ^
答案

正如here所述,这是name hiding的一个例子。通过在命名空间operator<<中定义MyNamespace,可以隐藏更高名称空间(如全局)中的所有定义。

请注意,如here所述:

[...]此功能不会干扰Koenig查找[...],因此仍会找到来自std::的IO运营商。

(Qazxswpoi)

解决方案是使用details about Koenig lookup指令引用其他命名空间中的重载,如usinghere所述。 Michael Nastenko在评论中提到了这一点。

因此hereusing ::operator<<;指的是全局命名空间。

因此代码将变为:

::

#include <string> #include <iostream> typedef std::pair<std::string, std::string> StringPair; std::ostream& operator<<(std::ostream& os, const StringPair &pair) { os << pair.first << '.' << pair.second; return os; } namespace MyNamespace { class MyClass {}; using ::operator<<; std::ostream& operator<< (std::ostream&, const MyClass &); void xxx(); } void MyNamespace::xxx() { StringPair pair("1","2"); std::cout<<pair<<std::endl; } int main() { MyNamespace::xxx(); return 0; }

以上是关于命名空间中的ostream operator <<隐藏其他ostream :: operator [duplicate]的主要内容,如果未能解决你的问题,请参考以下文章

流运算符的重载

cincout的重载

我真的需要为命名空间中的类的朋友运算符<< 向后弯腰吗?

‘operator<<’ 不匹配(操作数类型是 ‘std::ostream’ aka ‘std::basic_ostream<char>’ 和 ‘const std::type

错误:'operator<<' 不匹配(操作数类型为'std::ostream' aka'std::basic_ostream<char>' 和'std::_List_iter

模板类中的友元函数