使用 params 关键字可以指定采用数目可变的参数的方法参数。
可以发送参数声明中所指定类型的逗号分隔的参数列表或指定类型的参数数组。 还可以不发送参数。 如果未发送任何参数,则 params 列表的长度为零。
在方法声明中的 params 关键字之后不允许任何其他参数,并且在方法声明中只允许一个 params 关键字。
注意事项:
1. 只能在一维数组上使用params关键字。
2. 不能重载一个只基于params关键字的方法。params关键字不构成方法的签名的一部分。
如:
1
2
3
4
5
|
//编译时错误:重复访问
public
static
int
Min(
int
[] paramList)
.............
public
static
int
Min(
params
int
[] paramList)
.............
|
3. 不允许ref或out params数组
1
2
3
4
5
|
//编译时错误
public
static
int
Min(
ref
params
int
[] paramList)
.............
public
static
int
Min(
out
params
int
[] paramList)
.............
|
4. params 数组必须是方法的最后一个参数(也就是只能有一个params数组参数)
1
2
|
public
static
int
Min(
params
int
[] paramList,
int
i)
.............
|
5. 编译器会检查并拒绝任何可能有歧义的重载
6. 非params方法总是优先于一个params方法。也就是说,如果愿意,仍然可以为普通情况创建一个方法的重载版本,
如:
1
2
|
public
static
int
Min(
int
leftHandSide,
int
rightHandSide)
.............
|
优于:
1
2
|
public
static
int
Min(
params
int
[] paramList)
.............
|
第一个先被调用(声明不带params数组参数的方法,或许是一种有用的优化技术,可以避免编译器创建和填充太多的数组)。
1
2
3
4
5
|
class
Black
{
public
static
int
Hole(
params
object
[] paramList)
.............
}
|
System.Object(object)是所有类的根,使用params object数组来声明一个方法,它能接受任意数量的object参数;换言之,不仅参数的数量是任意的,参数的类型也可以是任意的。所以,此方法称为Black.Hole(黑洞)
1. 可以不向它传递任何参数
2. 可以在调用它时,传递null作为参数
3. 可以向它传递一个实际的数组。也就是说,可以人工创建本由编译器来创建的数组
4. 可以向它传递不同类型的其他任何参数,这些参数将自动封装到一个object数组
例子
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() { // 你可以发送一个以逗号分隔的指定类型的参数 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[] */