同步、异步、堵塞、非堵塞概念总结

同步、异步、堵塞、非堵塞对于程序员来讲都不会陌生,不管是看相关书籍,仍是面试,都会涉及到这四个词,下面给出个人理解,若有不对请多指教。程序员

同步与异步

服务(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任务对于业务来讲是一个异步操做,也能够说是一个异步服务。spa

阻塞和非阻塞

若是说线程是程序工做的基本单位、服务是要处理的内容,那么阻塞是指工做线程须要等待服务的响应结果才会处理下一个服务,不然工做线程会一直处于等待状态。非阻塞是指工做线程不需等待结果直接处理下一个服务。线程

  • 阻塞

服务的执行在Handler结果返回以前,工做线程会一直等待。3d

  • 非阻塞

服务的执行不依赖Handler返回结果,工做线程直接处理下一个服务。blog

总结

  • 同步:服务依赖任务的执行结果
  • 异步:服务不依赖任务的执行结果
  • 阻塞:服务执行时线程会出现等待状态
  • 非阻塞:不服务执行时线程不会出现等待状态
相关文章
相关标签/搜索