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);