次の方法で共有


ユーザー定義の演算子 (C++/CLI)

マネージ型のユーザー定義の演算子は静的メンバーとして許可されているか、またはグローバル スコープでメンバー、または例に反映されます。ただし、静的な演算子のみ Visual C++ 以外の言語で記述されたクライアントからメタデータにアクセスできます。

参照型では、静的なユーザー定義の演算子のパラメーターの 1 つが、これらの 1 である必要があります:

  • 外側の型のインスタンスへのハンドル (^) のtype。

  • 外側の型のインスタンスへのハンドルへの参照型の間接参照 (typeの ^& か type^%)。

値型では、静的なユーザー定義の演算子のパラメーターの 1 つが、これらの 1 である必要があります:

  • 外側の値型と同じ型の。

  • 外側の型へのポインターの型の間接参照 (typeの ^)。

  • 外側の型への参照型の間接参照 (%typeか type&)。

  • ハンドルへの参照型の間接参照 (type^% か typeの ^&)。

次の演算子を定義できます:

[演算子]

単項演算子または二項形式か。

!

単項式

!=

Binary

%

Binary

&

単項および二項

&&

Binary

*

単項および二項

+

単項および二項

++

単項式

,

Binary

-

単項および二項

--

単項式

->

単項式

/

Binary

<

Binary

<<

Binary

<=

Binary

=

Binary

==

Binary

>

Binary

>=

Binary

>>

Binary

^

Binary

false

単項式

true

単項式

|

Binary

||

Binary

~

単項式

使用例

// 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);
}
  

次の例ではコンパイルに /clr を使用する場合にのみ利用できる演算子の統合を示します。演算子の統合は、代入演算子の左側には CLR 型を指定すると、1 種類が定義されていない場合、二項演算子の割り当てのフォームを作成します。

// 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);
}
  

参照

関連項目

クラスと構造体 (C++ コンポーネント拡張)