1.c#的异步实现,之前代码编写大都开几个线程。
现可以使用“async+await”方式实现异步(具体不详细介绍,暂且止在会用,仅仅是c#更新史上一个工具):
static void Main(string[] args)
{
method1();
method2();//不会等待method1执行结束,再执行method2
Console.ReadKey();
}//结果输出是"method 1"和"method 2"字符串交替出现,但不会严格按照1:1交替出现
private static async Task method1()//必须使用task或task<T>做返回
{
await Task.Run(() =>
{
for (int i = 0; i < 100; i++)
{
Console.WriteLine("method 1");
}
});
}
private static void method2()
{
for (int i = 0; i < 25; i++)
{
Console.WriteLine("method 2");
}
}
2.委托函数
旧的使用方法:需要先定义委托类型,然后定义一个符合委托类型签名的函数,
在调用前,需声明并创建委托对象,将指定函数与委托进行关联。
public delegate int Math(int param1,int param2);定义委托类型
Public int Add(int param1,int param2)//定义同签名函数
{
Return param1+param2;
}
Math math;//声明委托
math=new Math(Add);创建委托对象,与指定进行关联
math(3,4);//调用委托函数
现在可以使用内置委托类型:
Func<int,int,int> math=Add;//指定委托对象并关联函数
math(3,4);//调用委托函数
Action委托具有Action<T>、Action<T1,T2>、Action<T1,T2,T3>……Action<T1,……T16>多达16个的重载,其中传入参数均采用泛型中的类型参数T,涵盖了几乎所有可能存在的无返回值的委托类型。Func则具有Func<TResult>、Func<T,Tresult>、Func<T1,T2,T3……,Tresult>17种类型重载,T1……T16为出入参数,Tresult为返回类型。
既然是委托类型,也同样可以与匿名函数、或者采用Lambda表达式结合使用:
匿名函数:
Func<int,int,int> math=delegate(int param1,int param2)
{
Return param1+param2;
}
Lambda:
Func<int,int,int> math=(param1,param2)=>
{
Return param1+param2;
}
Action的使用如同上面Func的使用一样,只是缺少了返回类型,直接调用委托函数。
Public void Add(int param1,int param2)
{
MessageBox.show((param1+param2).ToString());
}
//遇到此类的委托函数调用,那我们就可以直接用Action了:
Action<int,int> math=Add;
math(3,4);