最近频繁使用异步所以自己综合的学习了一把异步相关的知识,自己稍加整理了一下(这也是我试着写的第一篇,如果有不对的,希望大神来指正!)
首先是 委托实现的异步
class program
{
public delegate int weituo();//定义了个委托
public int xxx()
{
thread.sleep(3000);
console.writeline("11111.");
return 1;
}
///定义了个方法
static void main(string[] args)
{
weituo a =new weituo(new program().xxx);
iasyncresult result= a.begininvoke(null,null);
console.writeline("1234");
thread.sleep(1000);
int i= a.endinvoke(result);
console.writeline("1235");
console.writeline(i.tostring());
console.readline();
}
}
执行结果如下;
接着是 async /await 的异步实现
class program
{
public static async void xxx()
{
int i = 0;
await task.run(() =>
{
new program().xxxa();
});
console.writeline("123");
}
public async task<int> xxxa()
{
thread.sleep(3000);
console.writeline("11111.");
return (2);
}
static void main(string[] args)
{
xxx();
console.writeline("1234");
console.writeline("1235");
console.readline();
}
}
执行结果
如果将
public static async void xxx()
{
int i = 0;
await task.run(() =>
{
new program().xxxa();
});
console.writeline("123");
}
改为
public static async void xxx()
{
int i = 0;
await new program().xxxa();
console.writeline("123");
}
结果变为
说明,async与await关键字本身并不会产生多线程;
await 不会开启新的线程,当前线程会一直往下走直到遇到真正的async方法(比如说httpclient.getstringasync),这个方法的内部会用task.run或者task.factory.startnew 去开启线程。也就是如果方法不是.net为我们提供的async方法,我们需要自己创建task,才会真正的去创建线程
如对本文有疑问, 点击进行留言回复!!
(精华)2020年7月21日 ASP.NET Core 容器伪属性注入
网友评论