对C++中的istream和ostream运算符进行双重重载

Double overloading the istream and ostream operators in C++

本文关键字:重载 运算符 ostream C++ 中的 istream      更新时间:2023-10-16

我有一个Fraction类,它允许以c/d的形式输入分数。我可以很好地输出和输入分数,但当我用如下所示的自定义函数修改它们时,它什么都不做。

我有以下过载>>和<lt;操作员:

  ostream& operator<<(ostream &out, const Fraction &f)
{
    char x = '/';
    out << f.num;
    out << x;
    out << f.den;
    return out;
}
istream& operator>>(istream &in, Fraction &r)
{
    //in >> r;
    int whole = 0, num, den = 1;
    char next;
    in >> num;
    next = in.peek();
    if(next == '+'){
        in.get();
        whole = num;
        in >> num;
        next = in.peek();
    }
    if(next == '/'){
        in.get();
        in >> den;
    }
    if(whole != 0){
        num += (whole * den);
    }
    if(den == 0){
        den = 1;
    }
    r.num = num;
    r.den = den;
    return in;
}

此外,我有一个函数,它使两个分数具有相同的公约数:

void setEqualDen(Fraction a, Fraction b){
    int tempa = a.den;
    int tempb = b.den;
    a.den *= tempb;
    b.den *= tempa;
    a.num *= tempb;
    b.num *= tempa;
}

然后我尝试在主界面中输出结果,如下所示:

setEqualDen(Fa, Fb);
    cout << "The fractions are " << Fa << " , " << Fb <<   
             endl;

这不起作用。是否存在诸如使<lt;和C++中的>>运算符,或者我的语法只是缺少了什么?

您想要函数定义中的&,因为您需要通过引用传递,因为您正在修改`Fractions。

void setEqualDen(Fraction &a, Fraction &b){
    int tempa = a.den;
    int tempb = b.den;
    a.den *= tempb;
    b.den *= tempa;
    a.num *= tempb;
    b.num *= tempa;
}

您需要检查输入错误并跳过空白。我建议使用临时数字来包含第一个数字,因为它可以是整数也可以是分子。区分需要在检测到"/"之后进行。

std::istream& operator>>(std::istream& inp, Fraction& f)
{
  int temp = 0;
  f.num = 0;
  f.den = 1;
  inp >> temp;  // Could be whole number or numerator.
  if (inp)
  {
    int whole = temp;
    int numerator = 0;
    inp >> numerator;
    if (!inp)
    {
      // Let's assume that the input failed because of the '/' symbol.
      numerator = temp;
      whole = 0;
      inp.clear();
    }
    else
    {
      inp.ignore(1000, '/'); // Skip over the '/'
    }
    int denominator = 1;
    inp >> denominator;
    if (denominator == 0) denominator = 1;
    numerator += whole * denominator;
    f.num = numerator;
    f.den = denominator;
  }
  return inp;
}