ユーザー定義の演算子 (C++/CLI)User-Defined Operators (C++/CLI)

マネージ型の場合、ユーザー定義の演算子は、静的メンバーまたはインスタンス メンバー、またはグローバル スコープで許可されます。User-defined operators for managed types are allowed as static members or instance members, or at global scope. ただし、Visual C 以外の言語で記述されているクライアントにメタデータを介してアクセスできるは静的演算子のみです。However, only static operators are accessible through metadata to clients that are written in a language other than Visual C++.

参照型でこれらのいずれかに静的なユーザー定義演算子のパラメーターのいずれかの必要があります。In a reference type, one of the parameters of a static user-defined operator must be one of these:

  • ハンドル (type ^)、外側の型のインスタンスにします。A handle (type ^) to an instance of the enclosing type.

  • 参照型の間接参照 (type^ (& a) または型 ^ %)それを囲む型のインスタンスへのハンドル。A reference type indirection (type^& or type^%) to a handle to an instance of the enclosing type.

値の型でこれらのいずれかに静的なユーザー定義演算子のパラメーターのいずれかの必要があります。In a value type, one of the parameters of a static user-defined operator must be one of these:

  • 外側の値の型と同じ型。Of the same type as the enclosing value type.

  • ポインター型の間接参照 (type^)、外側の型にします。A pointer type indirection (type^) to the enclosing type.

  • 参照型の間接参照 (type% またはtype&)、外側の型にします。A reference type indirection (type% or type&) to the enclosing type.

  • 参照型の間接参照 (type^ % またはtype^ (& a)) のハンドルにします。A reference type indirection (type^% or type^&) to the handle.

次の演算子を定義できます。You can define the following operators:

演算子Operator 単項/バイナリ形式ですか。Unary/Binary Forms?
!! 単項Unary
!=!= 2 項Binary
% 2 項Binary
& 単項演算子および 2 項演算子Unary and Binary
&& 2 項Binary
* 単項演算子および 2 項演算子Unary and Binary
+ 単項演算子および 2 項演算子Unary and Binary
++ 単項Unary
,, 2 項Binary
- 単項演算子および 2 項演算子Unary and Binary
-- 単項Unary
-> 単項Unary
/ 2 項Binary
< 2 項Binary
<< 2 項Binary
<= 2 項Binary
= 2 項Binary
== 2 項Binary
> 2 項Binary
>= 2 項Binary
>> 2 項Binary
^ 2 項Binary
Falsefalse 単項Unary
truetrue 単項Unary
|| 2 項Binary
|||| 2 項Binary
~ 単項Unary

Example

// mcppv2_user-defined_operators.cpp
// compile with: /clr
using namespace System;
public ref struct X {
   X(int i) : m_i(i) {}
   X() {}

   int m_i;

   // static, binary, user-defined operator
   static X ^ operator + (X^ me, int i) {
      return (gcnew X(me -> m_i + i));
   }

   // instance, binary, user-defined operator
   X^ operator -( int i ) {
      return gcnew X(this->m_i - i);
   }

   // instance, unary, user-defined pre-increment operator
   X^ operator ++() {
      return gcnew X(this->m_i++);
   }

   // instance, unary, user-defined post-increment operator
   X^ operator ++(int i) {
      return gcnew X(this->m_i++);
   }

   // static, unary user-defined pre- and post-increment operator
   static X^ operator-- (X^ me) {
      return (gcnew X(me -> m_i - 1));
   }
};

int main() {
   X ^hX = gcnew X(-5);
   System::Console::WriteLine(hX -> m_i);

   hX = hX + 1;
   System::Console::WriteLine(hX -> m_i);

   hX = hX - (-1);
   System::Console::WriteLine(hX -> m_i);

   ++hX;
   System::Console::WriteLine(hX -> m_i);

   hX++;
   System::Console::WriteLine(hX -> m_i);

   hX--;
   System::Console::WriteLine(hX -> m_i);

   --hX;
   System::Console::WriteLine(hX -> m_i);
}
-5
-4
-3
-2
-1
-2
-3

Example

次の例は、使用する場合にのみ使用される演算子合成 /clrをコンパイルします。The following sample demonstrates operator synthesis, which is only available when you use /clr to compile. 複合演算子の使用は二項演算子の割り当てフォームを作成します、1 つの場合は定義されず、CLR 型の代入演算子の左側にあるが。Operator synthesis creates the assignment form of a binary operator, if one is not defined, where the left-hand side of the assignment operator has a CLR type.

// mcppv2_user-defined_operators_2.cpp
// compile with: /clr
ref struct A {
   A(int n) : m_n(n) {};
   static A^ operator + (A^ r1, A^ r2) {
      return gcnew A( r1->m_n + r2->m_n);
   };
   int m_n;
};

int main() {
   A^ a1 = gcnew A(10);
   A^ a2 = gcnew A(20);

   a1 += a2;   // a1 = a1 + a2   += not defined in source
   System::Console::WriteLine(a1->m_n);
}
30

関連項目See also

クラスと構造体Classes and Structs