同步、异步、堵塞、非堵塞对于程序员来说都不会陌生,无论是看相关书籍,还是面试,都会涉及到这四个词,下面给出我的理解,如有不对请多指教。
同步与异步
服务(Service)被分割成多个任务(Task),服务的执行结果是否要求任务最终按顺序执行。服务的结果依赖所有任务的执行称为同步服务;服务的结果不依赖所有的任务称为异步服务。下面举例说明:
- 同步
服务(Service)开始被分割为TaskA,TaskB,TaskC三个任务,TaskB的执行依赖于TaskA的执行,服务最后结果依赖于TaskB、TaskC,所有任务对业务来说都是同步操作。(这里也可以把TaskA、TaskB理解成一个任务,当然啦可以把TaskA、TaskB、TaskC理解成一个任务。我们平时写的比较多的就是同步代码)
- 异步
服务(Service)开始被分割为TaskA,TaskB,TaskC三个任务,TaskB的执行依赖于TaskA的执行,业务最后结果依赖于TaskB,TaskC的执行结果或者说TaskC中涉及到的数据对服务来说不重要甚至是不需要,所以TaskC任务对于业务来说是一个异步操作,也可以说是一个异步服务。
阻塞和非阻塞
如果说线程是程序工作的基本单位、服务是要处理的内容,那么阻塞是指工作线程需要等待服务的响应结果才会处理下一个服务,否则工作线程会一直处于等待状态。非阻塞是指工作线程不需等待结果直接处理下一个服务。
- 阻塞
服务的执行在Handler结果返回之前,工作线程会一直等待。
- 非阻塞
服务的执行不依赖Handler返回结果,工作线程直接处理下一个服务。
总结
- 同步:服务依赖任务的执行结果
- 异步:服务不依赖任务的执行结果
- 阻塞:服务执行时线程会出现等待状态
- 非阻塞:不服务执行时线程不会出现等待状态