Udostępnij za pośrednictwem


Delegaty ogólne (Visual C++)

Z delegatów, można używać parametrów typ ogólny .Aby uzyskać więcej informacji dotyczących delegatów, zobacz delegate (C++ Component Extensions).

[attributes] 
generic < [class | typename] type-parameter-identifiers >
[type-parameter-constraints-clauses]
[accessibility-modifiers] delegate result-type identifier  
([formal-parameters]);

Parametry

  • attributes(Opcjonalnie)
    Dodatkowe informacje deklaracyjne.Aby uzyskać więcej informacji dotyczących atrybutów i klas atrybut Zobacz atrybuty.

  • Typparametr-identyfikator(s)
    Rozdzielana przecinkami lista identyfikatorów dla parametrów typu.

  • type-parameter-constraints-clauses
    formularz określony wOgraniczenia parametrów typu ogólnego (C++/CLI)

  • ułatwienia dostępu-modyfikatorów (opcjonalnie)
    Modyfikatorów ułatwień dostępu (np.public, private).

  • typ wyników
    Zwracany typ delegat.

  • identyfikator
    Nazwa delegat.

  • Parametry formalne (opcjonalnie)
    parametr listy delegat.

Przykład

Parametry typu delegat są określone w punkcie, w którym delegat obiekt jest tworzony.Zarówno delegat i metoda skojarzony z nim musi mieć ten sam podpis.Oto przykład deklaracji rodzajowy delegat .

// generics_generic_delegate1.cpp
// compile with: /clr /c
generic < class ItemType>
delegate ItemType GenDelegate(ItemType p1, ItemType% p2);

Poniższy przykład pokazuje, że

  • Nie można używać tego samego delegat obiekt z różnymi typami konstruowanej.Tworzenie różnych delegat obiektów dla różnych typów.

  • Rodzajowy delegat można skojarzyć z metoda ogólna.

  • Gdy metoda ogólna nosi nazwę bez określania argumentów typu, kompilator próbuje wywnioskować argumentów typu dla wywołania.

// generics_generic_delegate2.cpp
// compile with: /clr
generic < class ItemType>
delegate ItemType GenDelegate(ItemType p1, ItemType% p2);

generic < class ItemType>
ref struct MyGenClass {
   ItemType MyMethod(ItemType i, ItemType % j) {
      return ItemType();
   }
};

ref struct MyClass {
   generic < class ItemType>
   static ItemType MyStaticMethod(ItemType i, ItemType % j) {
      return ItemType();
   }
};

int main() {
   MyGenClass<int> ^ myObj1 = gcnew MyGenClass<int>();
   MyGenClass<double> ^ myObj2 = gcnew MyGenClass<double>();
   GenDelegate<int>^ myDelegate1 =
      gcnew GenDelegate<int>(myObj1, &MyGenClass<int>::MyMethod);

   GenDelegate<double>^ myDelegate2 = 
      gcnew GenDelegate<double>(myObj2, &MyGenClass<double>::MyMethod);

   GenDelegate<int>^ myDelegate =
      gcnew GenDelegate<int>(&MyClass::MyStaticMethod<int>);
}

Poniższy przykład deklaruje rodzajowy delegatGenDelegate<ItemType>, a następnie tworzy kojarząc z metoda MyMethod używający typu parametrItemType. Do tworzenia i wywoływane dwa wystąpienia delegat ( liczba całkowita i podwójne).

// generics_generic_delegate.cpp
// compile with: /clr
using namespace System;

// declare generic delegate
generic <typename ItemType>
delegate ItemType GenDelegate (ItemType p1, ItemType% p2);

// Declare a generic class:
generic <typename ItemType>
ref class MyGenClass {
public:
   ItemType MyMethod(ItemType p1, ItemType% p2) {
      p2 = p1;
      return p1;
    }
};

int main() {
   int i = 0, j = 0; 
   double m = 0.0, n = 0.0;

   MyGenClass<int>^ myObj1 = gcnew MyGenClass<int>();
   MyGenClass<double>^ myObj2 = gcnew MyGenClass<double>(); 

   // Instantiate a delegate using int.
   GenDelegate<int>^ MyDelegate1 = 
      gcnew GenDelegate<int>(myObj1, &MyGenClass<int>::MyMethod);

   // Invoke the integer delegate using MyMethod.
   i = MyDelegate1(123, j);

   Console::WriteLine(
      "Invoking the integer delegate: i = {0}, j = {1}", i, j);

   // Instantiate a delegate using double.
   GenDelegate<double>^ MyDelegate2 = 
      gcnew GenDelegate<double>(myObj2, &MyGenClass<double>::MyMethod);

   // Invoke the integer delegate using MyMethod.
   m = MyDelegate2(0.123, n);

   Console::WriteLine(
      "Invoking the double delegate: m = {0}, n = {1}", m, n);
}
  

Zobacz też

Inne zasoby

Typy ogólne (C++ Component Extensions)