インターフェイスのインデクサー (C# プログラミング ガイド)
interface でインデクサーを宣言することができます。 インターフェイスのインデクサーのアクセサーは、クラスのインデクサーのアクセサーと次の点で異なります。
- インターフェイスのアクセサーは、修飾子は使用しません。
- インターフェイスのアクセサーには通常、本文がありません。
アクセサーの目的は、インデクサーが読み取り/書き込み、読み取り専用、書き込み専用のどれかを示すことです。 インデクサーの実装をインターフェイスに定義できますが、めったに行われません。 インデクサーでは通常、データ フィールドにアクセスするための API が定義されます。データ フィールドはインターフェイスで定義できません。
インターフェイスのインデクサー アクセサーの例を次に示します。
public interface ISomeInterface
{
//...
// Indexer declaration:
string this[int index]
{
get;
set;
}
}
インデクサーのシグネチャは、同じインターフェイスで宣言されている他のすべてのインデクサーの署名とは異なる必要があります。
例
次の例では、インターフェイスのインデクサーを実装する方法について説明します。
// 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
*/
前の例では、インターフェイス メンバーの完全修飾名を使用して明示的なインターフェイス メンバーの実装を使用することができます。 次に例を示します。
string IIndexInterface.this[int index]
{
}
ただし、完全修飾名は、クラスが同じインデクサーの署名を持つ 2 つ以上のインターフェイスを実装するときにあいまいさを避けるためにのみ必要です。 たとえば、Employee
クラスが 2 つのインターフェイス ICitizen
と IEmployee
を実装し、両方のインターフェイスが同じインデクサーの署名を持っている場合、明示的なインターフェイス メンバーの実装が必要です。 つまり、次のインデクサーの宣言があります。
string IEmployee.this[int index]
{
}
これは、IEmployee
インターフェイス上でインデクサーを実装します。次の宣言があります。
string ICitizen.this[int index]
{
}
これは、ICitizen
インターフェイスでインデクサーを実装します。
関連項目
.NET