C ++単項演算子のオーバーロード
単項演算子のみ1オペランドの操作、単項演算子の例を以下に示します。
- インクリメント演算子(++)とデクリメント演算子( - )
- 単項マイナス演算子は、それが負の符号です( - )
- NOT論理演算子(!)
単項演算子は、典型的には、例えば、それらが動作しているオブジェクトの左側に表示されます!OBJの、-objと++ objを、時には彼らはまた、OBJ ++やobj--として、接尾辞として使用することができます。
( - )次の例は、どのようにオーバーロード単項マイナス演算子を示しています。
#include <iostream> using namespace std; class Distance { private: int feet; // 0 到无穷 int inches; // 0 到 12 public: // 所需的构造函数 Distance(){ feet = 0; inches = 0; } Distance(int f, int i){ feet = f; inches = i; } // 显示距离的方法 void displayDistance() { cout << "F: " << feet << " I:" << inches <<endl; } // 重载负运算符( - ) Distance operator- () { feet = -feet; inches = -inches; return Distance(feet, inches); } }; int main() { Distance D1(11, 10), D2(-5, 11); -D1; // 取相反数 D1.displayDistance(); // 距离 D1 -D2; // 取相反数 D2.displayDistance(); // 距离 D2 return 0; }
上記のコードはコンパイルされ、実行されると、次の結果を生成します。
F: -11 I:-10 F: 5 I:-11
私はあなたが論理NOT演算子をリロードしようとすることができ、上記の例は、あなたがより良いと同様、単項演算子オーバーロードの概念を理解するのに役立つことを願って(!)。