先看下面的代码:
public static class StringExtension
{
public staticvoid Foo(this string s)
{
Console.WriteLine("Foo invoked for {0}",s);
}
}
为什么这里会有一个this关键字,做什么用?其实这就是扩展方法!这个扩展方法在静态类中声明,定义一个静态方法,其中第一个参数定义可它的扩展类型。Foo()方法扩展了String类,因为它的第一个参数定义了String类型,为了区分扩展方法和一般的静态方法,扩展方法还需要给第一个参数使用this关键字。
现在就可以使用带string类型的Foo方法了:
string s="Hello"; s.Foo();
结果在控制台上显示Foo invoked for Hello ,因为Hello是传送给Foo方法的字符串。
归纳:扩展方法可以写入最初没有提供该方法的类中。还可以把方法添加到实现某个接口的任何类中,这样多个类可以使用相同的实现代码
参考地址:http://hi.baidu.com/jiang_yy_jiang/blog/item/34cca1634faf2f750d33fa03.html
建议链接:http://wordoor.com/
1、在switch语句中,如果没有任何 case 表达式与开关值匹配,则控制传递给跟在可选 default 标签后的语句。如果没有 default 标签,则控制传递到 switch 以外。
switch (id)
{
case 1 :
Console.WriteLine( " Lee " );
break ;
case 2 :
Console.WriteLine( " Tang " );
break ;
default:
Console.WriteLine( " Sorry, no one match this ID! " );
break ;
}
2、在泛型类和泛型方法中,在预先未知以下情况时,如何将默认值分配给参数化类型 T:
T 是引用类型还是值类型,如果 T 为值类型,则它是数值还是结构。
{
public T DoSTH(arg)
{
T temp = default (T);
if (arg != null )
{
temp = arg.Favs;
}
return temp;
}
//...
}
给定参数化类型 T 的一个变量 t,只有当 T 为引用类型时,语句 t = null 才有效;只有当 T 为数值类型而不是结构时,语句 t = 0 才能正常使用。解决方案是使用 default 关键字,此关键字对于引用类型会返回空,对于数值类型会返回零。对于结构,此关键字将返回初始化为零或空的每个结构成员,具体取决于这些结构是值类型还是引用类型。