Покажем вначале реализацию метода Plus и операции +: public Rational Plus(Rational a) { int u,v; u = m*a.n +n*a.m; v= n*a.n; return( new Rational(u, v)); }//Plus public static Rational operator +(Rational r1, Rational r2) { return (r1.Plus(r2)); } Метод Plus реализуется просто. По правилам сложения дробей вычисляется числитель и знаменатель результата, и эти данные становятся аргументами конструктора, создающего требуемое рациональное число, которое удовлетворяет правилам класса. Обратите внимание на то, как определяется операция класса. Именем соответствующего метода является сам знак операции, которому предшествует ключевое слово operator. Важно также помнить, что операция является статическим методом класса с атрибутом static.
Рис. 16.4. Сложение рациональных чисел В данном конкретном случае операция реализуется вызовом метода Plus. Как теперь все это работает? Вот пример: public void TestPlusRational() { Rational r1=new Rational(0,0), r2 = new Rational(1,1); Rational r3=new Rational(10,8), r4 = new Rational(2,6); Rational r5=new Rational(4,-12), r6 = new Rational (-12,-14); Rational r7,r8, r9,r10, r11, r12; r7 = r1.Plus(r2); r8 = r3.Plus(r4); r9 = r5.Plus(r6); r10 = r1+r2; r11 = r3+r4; r12 = r5+r6+r10+r11; r1.PrintRational("r1:(0,0)"); r2.PrintRational("r2:(1,1)"); r3.PrintRational("r3:(10,8)"); r4.PrintRational("r4:(2,6)"); r5.PrintRational("r5: (4,-12)"); r6.PrintRational ("r6: (-12,-14)"); r7.PrintRational("r7: (r1+r2)"); r8.PrintRational |