Operatori definiti dall'utente (C++/CLI)

Gli operatori definiti dall'utente per i tipi gestiti sono consentiti come membri statici o membri dell'istanza o nell'ambito globale. Tuttavia, solo gli operatori statici sono accessibili tramite metadati ai client scritti in un linguaggio diverso da Visual C++.

In un tipo riferimento, uno dei parametri di un operatore statico definito dall'utente deve essere uno dei seguenti:

  • Handle (type ^) a un'istanza del tipo di inclusione.

  • Riferimento indiretto di tipo (type^& o type^%) a un handle a un'istanza del tipo di inclusione.

In un tipo valore, uno dei parametri di un operatore statico definito dall'utente deve essere uno dei seguenti:

  • Dello stesso tipo del tipo di valore di inclusione.

  • Tipo di puntatore indiretto (type^) al tipo di inclusione.

  • Riferimento indiretto di tipo (type% o type&) al tipo di inclusione.

  • Riferimento indiretto di tipo (type^% o type^&) all'handle.

È possibile definire gli operatori seguenti:

Operatore Forme unarie/binarie?
! Unario
!= Binario
% Binario
& Unario e binario
&& Binario
* Unario e binario
+ Unario e binario
++ Unario
, Binario
- Unario e binario
-- Unario
-> Unario
/ Binario
< Binario
<< Binario
<= Binario
= Binario
== Binario
> Binario
>= Binario
>> Binario
^ Binario
false Unario
true Unario
| Binario
|| Binario
~ Unario

Esempio: Operatori definiti dall'utente

// 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

Esempio: Sintesi dell'operatore

Nell'esempio seguente viene illustrata la sintesi degli operatori, disponibile solo quando si usa /clr per la compilazione. La sintesi degli operatori crea il formato di assegnazione di un operatore binario, se non è definito, in cui il lato sinistro dell'operatore di assegnazione ha un tipo CLR.

// 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

Vedi anche

Classi e struct