Jak zaimplementować i wywołać niestandardową metodę rozszerzenia (Przewodnik programowania w języku C#)
W tym artykule pokazano, jak zaimplementować własne metody rozszerzenia dla dowolnego typu platformy .NET. Kod klienta może używać metod rozszerzenia. Projekty klienckie muszą odwoływać się do zestawu, który je zawiera. Projekty klienckie muszą dodać dyrektywę using określającą przestrzeń nazw, w której zdefiniowano metody rozszerzenia.
Aby zdefiniować i wywołać metodę rozszerzenia:
- Zdefiniuj klasę statyczną zawierającą metodę rozszerzenia. Nie można zagnieżdżać klasy wewnątrz innego typu i musi być widoczna dla kodu klienta. Aby uzyskać więcej informacji na temat reguł ułatwień dostępu, zobacz Modyfikatory dostępu.
- Zaimplementuj metodę rozszerzenia jako metodę statyczną z co najmniej taką samą widocznością jak zawierająca klasa.
- Pierwszy parametr metody określa typ, na którym działa metoda; musi być poprzedzony tym modyfikatorem.
- W kodzie wywołującym dodaj dyrektywę
using
, aby określić przestrzeń nazw zawierającą klasę metody rozszerzenia. - Wywołaj metody jako metody wystąpienia dla typu.
Uwaga
Pierwszy parametr nie jest określony przez wywołanie kodu, ponieważ reprezentuje typ, na którym jest stosowany operator, a kompilator zna już typ obiektu. Wystarczy podać argumenty parametrów od 2 do n
.
Poniższy przykład implementuje metodę rozszerzenia o nazwie WordCount
w CustomExtensions.StringExtension
klasie . Metoda działa na String klasie, która jest określona jako pierwszy parametr metody. CustomExtensions
Przestrzeń nazw jest importowana do przestrzeni nazw aplikacji, a metoda jest wywoływana Main
wewnątrz metody .
using CustomExtensions;
string s = "The quick brown fox jumped over the lazy dog.";
// Call the method as if it were an
// instance method on the type. Note that the first
// parameter is not specified by the calling code.
int i = s.WordCount();
System.Console.WriteLine("Word count of s is {0}", i);
namespace CustomExtensions
{
// Extension methods must be defined in a static class.
public static class StringExtension
{
// This is the extension method.
// The first parameter takes the "this" modifier
// and specifies the type for which the method is defined.
public static int WordCount(this string str)
{
return str.Split(new char[] {' ', '.','?'}, StringSplitOptions.RemoveEmptyEntries).Length;
}
}
}
Rozpoznawanie przeciążenia preferuje wystąpienie lub metodę statyczną zdefiniowaną przez sam typ do metod rozszerzeń. Metody rozszerzeń nie mogą uzyskać dostępu do żadnych danych prywatnych w klasie rozszerzonej.