#include <iostream>
class fraction {
int n, d;
public:
fraction(){}
fraction(int n, int d) : n(n), d(d) {}
int getter() { return n, d; }
friend std::istream& operator>>(std::istream& stream, const fraction& a) {
stream >> a;
return stream;
}
friend std::ostream& operator<<(std::ostream& stream, const fraction& a) {
stream << a;
return stream;
}
friend fraction operator*(const fraction& a, const fraction& b) {
int pN = a.n * b.n;
int pD = b.n * b.d;
return fraction(pN, pD);
}
};
int main()
{
fraction f1;
std::cout << "Enter fraction 1: ";
std::cin >> f1;
fraction f2;
std::cout << "Enter fraction 2: ";
std::cin >> f2;
std::cout << f1 << " * " << f2 << " is " << f1 * f2 << '\n'; // note: The result of f1 * f2 is an r-value
return 0;
}
编译错误说明:
operator<< and operator>> recursive on all paths, function will cause a stack overflow 我不知道这意味着什么。在所有路径上递归意味着什么?哪个函数将导致堆栈溢出?
当你执行时:
stream >> a;
您调用的函数与运行的函数相同friend std::istream& operator>>(std::istream& stream, const fraction& a).
所以你会打电话给自己(递归一次又一次,一次又一次.没有尽头。这反过来意味着分配给堆叠在某个时候会筋疲力尽(因为每个人框架(占用一些空间),它将导致堆栈溢出.
相反,您必须对fraction论辩a,最有可能指的是a.n和a.d.
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。