params (referência de C#)

O params palavra-chave permite que você especifique um parâmetro do método que leva a um número variável de argumentos.

Você pode enviar uma lista separada por vírgulas dos argumentos do tipo especificado na declaração de parâmetro ou matriz de argumentos do tipo especificado. Você também pode enviar sem argumentos.

Nenhum parâmetro adicional é permitido após o params palavra-chave em uma declaração de método e apenas uma params palavra-chave é permitida em uma declaração de método.

Exemplo

O exemplo a seguir demonstra várias maneiras em que os argumentos podem ser enviados para um params parâmetro.

public class MyClass
{
    public static void UseParams(params int[] list)
    {
        for (int i = 0; i < list.Length; i++)
        {
            Console.Write(list[i] + " ");
        }
        Console.WriteLine();
    }

    public static void UseParams2(params object[] list)
    {
        for (int i = 0; i < list.Length; i++)
        {
            Console.Write(list[i] + " ");
        }
        Console.WriteLine();
    }

    static void Main()
    {
        // You can send a comma-separated list of arguments of the 
        // specified type.
        UseParams(1, 2, 3, 4);
        UseParams2(1, 'a', "test");

        // A params parameter accepts zero or more arguments.
        // The following calling statement displays only a blank line.
        UseParams2();

        // An array argument can be passed, as long as the array
        // type matches the parameter type of the method being called.
        int[] myIntArray = { 5, 6, 7, 8, 9 };
        UseParams(myIntArray);

        object[] myObjArray = { 2, 'b', "test", "again" };
        UseParams2(myObjArray);

        // The following call causes a compiler error because the object
        // array cannot be converted into an integer array.
        //UseParams(myObjArray);

        // The following call does not cause an error, but the entire 
        // integer array becomes the first element of the params array.
        UseParams2(myIntArray);
    }
}
/*
Output:
    1 2 3 4
    1 a test

    5 6 7 8 9
    2 b test again
    System.Int32[]
*/

Especificação da linguagem C#

Para obter mais informações, consulte C# Language Specification A especificação de linguagem é a fonte definitiva para a sintaxe e o uso de C#.

Consulte também

Referência

C# Keywords

Parâmetros do método (referência de C#)

Conceitos

C# Programming Guide

Outros recursos

C# Reference