Indexadores em Interfaces (guia de programação de C#)
Os indexadores podem ser declarados em um interface (Referência de C#). Acessadores de indexadores de interface diferem dos acessadores de classe indexadores das seguintes maneiras:
Acessadores de interface não usam modificadores.
Um acessador de interface não tem um corpo.
Portanto, é o objetivo do acessador indicar se o indexador é leitura-gravação, somente leitura ou somente para gravação.
Este é um exemplo de um acessador do indexador de interface:
public interface ISomeInterface
{
//...
// Indexer declaration:
string this[int index]
{
get;
set;
}
}
A assinatura de um indexador deve diferir de assinaturas de todos os outros indexadores declaradas na interface do mesma.
Exemplo
O exemplo a seguir mostra como implementar os indexadores de interface.
// Indexer on an interface:
public interface ISomeInterface
{
// Indexer declaration:
int this[int index]
{
get;
set;
}
}
// Implementing the interface.
class IndexerClass : ISomeInterface
{
private int[] arr = new int[100];
public int this[int index] // indexer declaration
{
get
{
// The arr object will throw IndexOutOfRange exception.
return arr[index];
}
set
{
arr[index] = value;
}
}
}
class MainClass
{
static void Main()
{
IndexerClass test = new IndexerClass();
System.Random rand = new System.Random();
// 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 #{0} = {1}", i, test[i]);
}
// Keep the console window open in debug mode.
System.Console.WriteLine("Press any key to exit.");
System.Console.ReadKey();
}
}
/* 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
*/
No exemplo anterior, você poderia usar a implementação de um membro de interface explícita usando o nome totalmente qualificado do membro de interface. Por exemplo:
public string ISomeInterface.this
{
}
No entanto, o nome totalmente qualificado só é necessário para evitar ambigüidade quando a classe está implementando a mais de uma interface com a mesma assinatura do indexador. Por exemplo, se um Employee classe está implementando duas interfaces, ICitizen e IEmployeee ambas as interfaces têm a mesma assinatura do indexador, a implementação de membro de interface explícita é necessário. Ou seja, a seguinte declaração do indexador:
public string IEmployee.this
{
}
implementa o indexador de IEmployee interface, enquanto a seguinte declaração:
public string ICitizen.this
{
}
implementa o indexador de ICitizen interface.
Consulte também
Referência
Indexers (C# Programming Guide)
Properties (C# Programming Guide)
Interfaces (C# Programming Guide)