使用 ostream 和枚举类型重载 <<

nou*_*fal 2 c++ oop enums operator-overloading

以下是我的代码。我正在尝试打印一个枚举数据类型变量,一个直接使用其名称,另一个使用函数返回与原始变量相同的数据类型。

#include <iostream>

using namespace std;
enum days{SUN, MON, TUE, WED, THU, FRI, SAT};


inline days dayaftertomorrow(days d)
{
  return static_cast<days>((static_cast<int>(d) + 2) % 7);
}

ostream& operator<< (ostream& out, days& day)
{
  switch(day)
  {
    case SUN: out << "SUN"; break;
    case MON: out << "MON"; break;
    case TUE: out << "TUE"; break;
    case WED: out << "WED"; break;
    case THU: out << "THU"; break;
    case FRI: out << "FRI"; break;
    case SAT: out << "SAT"; break;
  }
  return out;
}


int main(int argc, char const *argv[]) {
  days d = MON, e;
  e = dayaftertomorrow(d);
  cout << d << "\t" << e << endl;
  cout << d << "\t" << dayaftertomorrow(d) << endl;
  return 0;
}
Run Code Online (Sandbox Code Playgroud)

我希望结果为

MON     WED
MON     WED
Run Code Online (Sandbox Code Playgroud)

但我越来越

MON     WED
MON     3
Run Code Online (Sandbox Code Playgroud)

我将如何解决这个问题?

son*_*yao 5

请注意,通过引用非常量来operator<<获取参数daydayaftertomorrow按值返回;什么dayaftertomorrow返回的是一个临时的,不能被绑定到参照非const。然后 for cout << dayaftertomorrow(d),您operator<<将不会被调用,枚举数将被隐式转换int,然后通过std::basic_ostream::operator<<打印出来;这就是为什么你得到3.

要解决此问题,您可以将参数类型更改为引用const;这可以绑定到临时。或者将其更改为按值传递。例如

ostream& operator<< (ostream& out, const days& day)
//                                 ~~~~~

ostream& operator<< (ostream& out, days day)
Run Code Online (Sandbox Code Playgroud)

居住