Внимательно проанализируем приведенную выше программу, начиная с перегру жаемого оператора +. Когда оператор + оперирует двумя объектами типа ThreeD, то величины их соответствующих координат складываются, как показано в объявлении операторного метода operator+. Следует, однако, иметь в виду, что этот оператор не видоизменяет значения своих операндов, а лишь возвращает новый объект типа ThreeD, содержащий результат операции сложения координат. Для того чтобы стало понятнее, почему операция + не меняет содержимое объектов, выступающих в роли ее операндов, обратимся к примеру обычной операции арифметического сложения: 10 + 12. Результат этой операции равен 22, но она не меняет ни число 10, ни число 12. Несмотря на то что ни одно из правил не препятствует перегруженному оператору изменить значение одного из своих операндов, все же лучше, чтобы действия этого оператора соответствовали его обычному назначению.
Обратите внимание на то, что метод operator+ возвращает объект типа ThreeD. Этот метод мог бы возвратить значение любого допустимого в C# типа, но благодаря тому что он возвращает объект типа ThreeD, оператор + можно использовать в та ких составных выражениях, как a+b+с. В данном случае выражение а+b дает резуль тат типа ThreeD, который можно затем сложить с объектом с того же типа. Если бы выражение а+b давало результат другого типа, то вычислить составное выражение a+b+с было бы просто невозможно.
Следует также подчеркнуть, что когда отдельные координаты точек складываются в операторе operator+, то в результате такого сложения получаются целые значения, поскольку отдельные координаты х, у и z представлены целыми величинами. Но сама перегрузка оператора + для объектов типа ThreeD не оказывает никакого влияния на операцию сложения целых значений, т.е. она не меняет первоначальное назначение этого оператора.
А теперь проанализируем операторный метод operator-. Оператор - действу ет так же, как и оператор +, но для него важен порядок следования операндов. Напом ним, что сложение носит коммутативный характер (от перестановки слагаемых сумма не меняется), чего нельзя сказать о вычитании: А - В не то же самое, что и В - А! Для всех двоичных операторов первым параметром операторного метода является левый операнд, а вторым параметром — правый операнд. Поэтому, реализуя перегружае мые варианты некоммутативных операторов, следует помнить, какой именно операнд должен быть указан слева и какой — справа. Перегрузка унарных операторов
Унарные операторы перегружаются таким же образом, как и бинарные. Главное отличие заключается, конечно, в том, что у них имеется лишь один операнд. В каче стве примера ниже приведен метод, перегружающий оператор унарного минуса для класса ThreeD. // Перегрузить оператор унарного минуса. public static ThreeD operator - (ThreeD op) { ThreeD result = new ThreeD ; result.x = -op.x; result.у = -op.у; result.z = -op.z; return result; }
В данном примере создается новый объект, в полях которого сохраняются отрица тельные значения операнда перегружаемого унарного оператора, после чего этот объ ект возвращается операторным методом. Обратите внимание на то, что сам операнд не меняется. Это означает, что и в данном случае обычное назначение оператора унарного минуса сохраняется. Например, результатом выражения а = -b
является отрицательное значение операнда b, но сам операнд b не меняется. В C# перегрузка операторов ++ и -- осуществляется довольно просто. Для этого достаточно возвратить инкрементированное или декрементированное значение, но не изменять вызывающий объект. А все остальное возьмет на себя компилятор С#, раз личая префиксные и постфиксные формы этих операторов. В качестве примера ниже приведен операторный метод operator++ для класса ThreeD. // Перегрузить унарный оператор ++. public static ThreeD operator ++(ThreeD op) { ThreeD result = new ThreeD; // Возвратить результат инкрементирования. result.x = op.x + 1; result.у = op.у + 1; result.z = op.z + 1; return result; }