命名参数和可选参数是在Visual C#2010中引入的新特性。 笨地儿我个瓜不兮兮的,今天才知道。
例如:
class Program
{
static void Main(string[] args)
{
//可选参数
Employee.DisplayInfo(24, "程序员"); //相当于 Employee.DisplayInfo(24, "程序员", 0, "未知",default(datetime));
Employee.DisplayInfo(25, "英语相关", 9500); //相当于 Employee.DisplayInfo(25, "英语相关", 9500,"未知",default(datetime));
//命名参数
//相当于Employee.DisplayInfo(30, "高级软件工程师", 20000, "Yathur",DateTime.Now);
Employee.DisplayInfo(30, Job: "高级软件工程师", Salary: 20000, Name: "Yathur", dt: DateTime.Now);
Employee.DisplayInfo(Age: 25, Job: "教师");
Console.Read();
}
}
public class Employee
{
public static void DisplayInfo(int Age, string Job, int Salary = default(int), string Name = "未知", DateTime dt = default(DateTime))
{
Console.WriteLine("姓名:" + Name + ", 年龄:" + Age + ", 职位:" + Job + ", 月薪" + Salary + " " + dt);
}
}运行结果:
在智能感知中,可选参数为方括号标识。
有了命名参数,调用时可以方便地按照形参名称进行,我们不需要记住或查找形参在所调用方法的形参列表中的顺序。 有了可选参数,当面对包含大量参数的方法时,如果含有默认值,我们可以只给有意义的参数指定实参,用起来方便了很多。
Employee.DisplayInfo( Age:25,Job:"教师");
注意:如果参数中存在数组参数,这个规则不成立。因为数组参数没有默认值,也要放到参数列表的最后。
CLR假定方法的参数是以传值方式进行的,但它允许以传引用的方式传递参数。C#通过Out和ref关键字可以传递指向实例的一个指针,而不是参数本身的值。
Out和Ref的使用区别:
运行结果:
相应的IL元数据:
当调用方法时,如果形参类型为实参类型的基类,一般会发生隐式转换。例如:
public static void Swap(object a, object b)
{
object t = a;
a = b;
b = t;
}
string a = "AAA", b = "BBB";
Swap(a, b);
Console.WriteLine("a=" + a + " b=" + b);
但是运行结果并非我们所愿,因为方法默认是以传值方式传递参数的,调用后原来的值是不会改变的。
当以传引用的方式向方法传递参数时,必须保证变量类型与方法签名中类型一致,而不能自动进行隐式转换,否则会产生编译错误。例如:
public static void Swap(ref object a, ref object b)
{
object t = a;
a = b;
b = t;
}
为了实现想要的效果,我们可以采用泛型。
public static void Swap<T>(ref T a, ref T b)
{
T t = a;
a = b;
b = t;
}
static void Main(string[] args)
{
string a = "AAA", b = "BBB";
Swap(ref a, ref b);
Console.WriteLine("a=" + a + " b=" + b);
Console.Read();
}
在C#中,可以使用Out或者ref关键字进行方法重载,例如下面的例子是合法的:
但是如果两个方法名称和参数相同,仅通过out和ref关键字是不能算作重载的。
某些时候,我们希望方法参数的个数是可变的,Params帮我们实现了这个想法。
假如不使用Params关键字,我们需要使用第①种调用方式。当添加Params关键字后,我们可以采用②③,调用方式看上去更加直观了。实现了传递可变数量参数的效果。
文章出处:跟小静读CLR via C#