async await 多线程

 

async await 并没有开启多线程  出现await的地方 只是开启了一个子线程继续往后执行  主线程返回 防止阻塞

相当于  await customerRepository.getall().ToListAllAsync()

 

主线程一直运行  碰到await   主线程就会返回干其他事情     

await后面的代码可以看成是子线程的回调  只有子线程执行完了才会执行await后面的代码       await后面的代码可能是子线程执行 可能是主线程执行

 

为什么没有返回值 方法返回值也写Task   因为主线程碰到await就返回了  对于主线程来说 是有返回值的  返回值就是await后面的 Task

 

 

 

*****************多线程*****************************

Task.Run()开启异步多线程
Task.WaitAll()参数是task集合 所有的线程都执行完毕才返回
多线程前提:业务可以并发执行
Task.WaitAny()参数是task集合 某个线程执行完毕就返回

多线程 用于可以并发执行的业务中   比如  同步产品 同步客户 等可以同时执行的任务 没有先后顺序的

*******

这两个线程等待的时间不能相同  如果相同 会存在线程安全的问题   

线程安全  多线程对同一个变量 方法进行操作 可以通过加锁解决线程安全问题

TaskWhenAll和Task.WaitAll都是等待全部任务完成  但是Task.WaitAll会发生阻塞  

TaskWhenAll在Task.WaitAll方法上面又封装了一层

 

在第一个线程写入的同时第二个线程也进行了写入  其中一个线程的写入会给覆盖 可以通过对写入日志这个方法进行加锁来保护线程安全

普通方法中

************ 

同时开启两个线程执行这两个任务 全部完成后继续往后面执行 

 也是同时开启两个线程  但不会等待两个线程执行完毕  主线程就直接往后面执行

********************

开启两个线程调用两个异步接口  全部完成后继续执行 

********************

Aaa和Baa都是两个异步的接口    刚进去两个方法  主线程继续往后执行 就直接结束了  两个线程并没有执行完

 

通过加锁解决线程安全

 

 

 

 

 

 

异步多线程一定是基于委托的  

 

异步多线程调试的时候打断点是没有用的  断点会乱跳  最好的办法就是在控制台打印日志    多个代码点都打印

 

获取当前线程ID

 

 

///   第一种 通过回调控制顺序

简写

 

BeginInvoke有三个参数  第一个是act委托执行的参数   第二个参数为回调(等第一个委托执行完才执行)  第三个参数在第一个委托执行完毕会当成一个状态参数传到回调委托中

执行完第一个委托  会把第一个委托的结果 和第三个状态参数 包成一个对象 当成回调委托的参数

 

//2222

通过等待

.IsCompleted 委托的状态 通过while循环判断当前的状态    只有完成后才能出while循环  否则会一直在while循环里面执行

 

 

 

 

 

posted @ 2018-11-29 21:12  几清  阅读(2183)  评论(0编辑  收藏  举报