我正在尝试执行一个简单的istream运算符重载,但由于某种原因,一旦进入此函数,程序就会进入无限循环。 请帮忙!
我的代码:
#include <iostream>
#include <string>
using namespace std;
class date{
int m_day,m_month,m_year;
public:
date(int day=1,int month=1,int year=2000){ //constructor
if (day>0 && day<32 && month>0 && month<13){
m_day =day;
m_month=month;
m_year=year;
}
}
friend ostream& operator<< (ostream& out, const date& d);
friend istream& operator>> (istream& in, const date& d);
};
istream& operator>> (istream& stream, const date& d){ //overload >>
stream >> d.m_day;
return stream;
}
void main(){
date date1;
cin>>date1; //check istream
getchar();
}
答案 0 :(得分:6)
这段代码对我来说似乎不对,因为您正在尝试修改const
对象(d)。
istream& operator>> (istream& stream, const date& d){ //overload >>
stream >> d.m_day;
return stream;
}
答案 1 :(得分:0)
实际上,Marc的回答并不能完全解决您的问题。发生的事情有点复杂:
您定义了接收date
的功能。这应该让编译器简单地拒绝编译你的函数。但问题在于:explicit
的构造函数具有每个参数的默认值。因此,只能使用一个参数调用它。由于它未标记date(i)
,因此它作为int的隐式转换运算符(如stream >> d.m_day
)。这意味着编译器可以将stream >> date(d.m_day)
解释为operator>>(istream& stream, const date& d)
。因此你的问题是:这是对date& d
的调用,你得到一个无限递归。
因此,您不仅要在operator>>
的重载上设置explicit
非const,还应该标记构造函数explicit date(int day=1, int month=1, int year=2000)
,例如
{{1}}
因此它不会充当隐式转换运算符。实际上,这应该对几乎每个只能使用一个参数的构造函数完成。