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循环里面执行