params (Riferimenti per C#)
Usando la parola chiave params
, è possibile specificare un parametro di metodo che usa un numero variabile di argomenti. Il tipo di parametro deve essere una matrice a dimensione singola.
In una dichiarazione di metodo non è possibile aggiungere altri parametri dopo la parola chiave params
ed è consentito l'uso di una sola parola chiave params
.
Se il tipo dichiarato del parametro non è una matrice multidimensionale singola, si verifica l'errore del params
compilatore CS0225 .
Quando si chiama un metodo con un params
parametro, è possibile passare:
- Elenco delimitato da virgole di argomenti del tipo degli elementi della matrice.
- Matrice di argomenti del tipo specificato.
- Nessun argomento. Se non vengono inviati argomenti, la lunghezza dell'elenco
params
è zero.
Esempio
Nell'esempio seguente vengono illustrati i vari modi in cui è possibile inviare argomenti al parametro params
.
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[]
*/
Specifiche del linguaggio C#
Per altre informazioni, vedere Specifica del linguaggio C#. La specifica del linguaggio costituisce il riferimento ufficiale principale per la sintassi e l'uso di C#.