Indexadores em interfaces (Guia de Programação em C#)

Os indexadores podem ser declarados em um interface (Referência de C#). Acessadores de indexadores interface diferem os 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 IEmployee, e ambas as interfaces têm a mesma assinatura do indexador, a implementação de um membro de interface explícita é necessária. Ou seja, a seguinte declaração do indexador:

public string IEmployee.this 
{ 
} 

implementa o indexador sobre o IEmployee interface, enquanto a declaração a seguir:

public string ICitizen.this 
{ 
} 

implementa o indexador sobre o ICitizen interface.

Consulte também

Referência

Indexadores (Guia de Programação em C#)

Propriedades (Guia de Programação em C#)

Interfaces (Guia de Programação em C#)

Conceitos

Guia de Programação em C#