Indeksatory w interfejsach (Przewodnik programowania w języku C#)
Indeksatory można zadeklarować w interfejsie. Metody dostępu indeksatorów interfejsu różnią się od metod dostępu indeksatorów klas w następujący sposób:
- Metody dostępu interfejsu nie używają modyfikatorów.
- Akcesorium interfejsu zwykle nie ma treści.
Celem metody dostępu jest wskazanie, czy indeksator jest tylko do odczytu, odczytu, tylko do odczytu, czy tylko do zapisu. Możesz zapewnić implementację indeksatora zdefiniowanego w interfejsie, ale jest to rzadkie. Indeksatory zazwyczaj definiują interfejs API w celu uzyskiwania dostępu do pól danych, a pola danych nie mogą być zdefiniowane w interfejsie.
Poniżej przedstawiono przykład metody dostępu indeksatora interfejsu:
public interface ISomeInterface
{
//...
// Indexer declaration:
string this[int index]
{
get;
set;
}
}
Podpis indeksatora musi różnić się od podpisów wszystkich innych indeksatorów zadeklarowanych w tym samym interfejsie.
Przykład
W poniższym przykładzie pokazano, jak zaimplementować indeksatory interfejsu.
// Indexer on an interface:
public interface IIndexInterface
{
// Indexer declaration:
int this[int index]
{
get;
set;
}
}
// Implementing the interface.
class IndexerClass : IIndexInterface
{
private int[] arr = new int[100];
public int this[int index] // indexer declaration
{
// The arr object will throw IndexOutOfRange exception.
get => arr[index];
set => arr[index] = value;
}
}
IndexerClass test = new IndexerClass();
System.Random rand = System.Random.Shared;
// Call the indexer to initialize its elements.
for (int i = 0; i < 10; i++)
{
test[i] = rand.Next();
}
for (int i = 0; i < 10; i++)
{
System.Console.WriteLine($"Element #{i} = {test[i]}");
}
/* Sample output:
Element #0 = 360877544
Element #1 = 327058047
Element #2 = 1913480832
Element #3 = 1519039937
Element #4 = 601472233
Element #5 = 323352310
Element #6 = 1422639981
Element #7 = 1797892494
Element #8 = 875761049
Element #9 = 393083859
*/
W poprzednim przykładzie można użyć jawnej implementacji składowej interfejsu przy użyciu w pełni kwalifikowanej nazwy elementu członkowskiego interfejsu. Na przykład
string IIndexInterface.this[int index]
{
}
Jednak w pełni kwalifikowana nazwa jest wymagana tylko w celu uniknięcia niejednoznaczności, gdy klasa implementuje więcej niż jeden interfejs z tym samym podpisem indeksatora. Jeśli na przykład Employee
klasa implementuje dwa interfejsy, ICitizen
a IEmployee
oba interfejsy mają ten sam podpis indeksatora, wymagana jest jawna implementacja składowa interfejsu. Oznacza to, że następująca deklaracja indeksatora:
string IEmployee.this[int index]
{
}
Implementuje indeksator w interfejsie IEmployee
, podczas gdy następująca deklaracja:
string ICitizen.this[int index]
{
}
Implementuje indeksator w interfejsie ICitizen
.
Zobacz też
- Indexers (Indeksatory)
- Właściwości
- Interfejsy