Operatory zdefiniowane przez użytkownika (C++/CLI)
Operatory zdefiniowane przez użytkownika dla typów zarządzanych są dozwolone jako statyczne elementy członkowskie lub elementy członkowskie wystąpienia lub w zakresie globalnym. Jednak tylko operatory statyczne są dostępne za pośrednictwem metadanych dla klientów napisanych w języku innym niż Visual C++.
W typie odwołania jeden z parametrów statycznego operatora zdefiniowanego przez użytkownika musi być jednym z następujących:
Uchwyt (
type
^) do wystąpienia otaczającego typu.Pośredni typ odwołania (
type
^& lub type^%) do dojścia do wystąpienia otaczającego typu.
W typie wartości jeden z parametrów statycznego operatora zdefiniowanego przez użytkownika musi być jednym z następujących:
Tego samego typu co typ otaczającej wartości.
Pośredni typ wskaźnika (
type
^) do otaczającego typu.Pośredni typ odwołania (
type
% lubtype
&) do otaczającego typu.Pośredni typ odwołania (
type
^% lubtype
^&) do uchwytu.
Można zdefiniować następujące operatory:
Operator | Formularze jednoargumentowe/binarne? |
---|---|
! | Jednoargumentowy |
!= | Plik binarny |
% | Plik binarny |
& | Jednoargumentowe i binarne |
&& | Plik binarny |
* | Jednoargumentowe i binarne |
+ | Jednoargumentowe i binarne |
++ | Jednoargumentowy |
, | Plik binarny |
- | Jednoargumentowe i binarne |
-- | Jednoargumentowy |
-> | Jednoargumentowy |
/ | Plik binarny |
< | Plik binarny |
<< | Plik binarny |
<= | Plik binarny |
= | Plik binarny |
== | Plik binarny |
> | Plik binarny |
>= | Plik binarny |
>> | Plik binarny |
^ | Plik binarny |
fałsz | Jednoargumentowy |
prawda | Jednoargumentowy |
| |
Plik binarny |
|| |
Plik binarny |
~ | Jednoargumentowy |
Przykład: operatory zdefiniowane przez użytkownika
// 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
Przykład: synteza operatorów
W poniższym przykładzie pokazano syntezę operatora, która jest dostępna tylko w przypadku użycia /clr do skompilowania. Synteza operatora tworzy formę przypisania operatora binarnego, jeśli nie jest zdefiniowany, gdzie lewa strona operatora przypisania ma typ 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