同步 异步 阻塞 非阻塞 区别

https://www.cnblogs.com/Anker/p/5965654.html

 

1、前言

  前一段时间出去面试,被问到同步、异步与阻塞、非阻塞的区别。我一时半会没有想出来,作为一个工作三年的人来说,实在很惭愧。我当时理解同步、异步属于两个进程中间的协作关系,例如使用浏览器访问一个网站,需要多次请求服务端,才能加载完整个页面的内容。同步的操作如下:浏览器首先发送第一个请求,等待服务器回复后,再发送第二个请求,依次类推,直到所有请求完成。异步的操作如下:浏览器发送第一个请求,可以不用等待服务器返回,可以继续发送第二个请求。阻塞与非阻塞属于进程的API执行动作的方式,例如进行需要read数据,阻塞方式操作流程是:如果没有数据,则read会一直等着数据到来,才能进行后续的动作;而非阻塞则是read没有到数据后,则可以进行后续的动作,当有数据的时候再回来读取。通常linux网络API默认都是阻塞的,例如connect、send、recv等。回答后感觉自己心里没有底,底层的关系到底是什么样的,比较虚,没能深入理解。

2、深入理解分析  

  回来以后,赶紧上网好好查查,加深学习一下。这两个概念在工作中经常用到这些,例如在linux网络IO中涉及到如下模型:

(1)阻塞式IO

(2)非阻塞式IO

(3)IO多路复用

(4)信号驱动IO

(5)异步IO

在知乎上面看到一些解释如下:

截图如下:

3、总结

  

  同步和异步针对应用程序来,关注的是程序中间的协作关系;阻塞与非阻塞更关注的是单个进程的执行状态。

同步:执行一个操作之后,等待结果,然后才继续执行后续的操作。

异步:执行一个操作后,可以去执行其他的操作,然后等待通知再回来执行刚才没执行完的操作。

阻塞:进程给CPU传达一个任务之后,一直等待CPU处理完成,然后才执行后面的操作。

非阻塞:进程给CPU传达任我后,继续处理后续的操作,隔断时间再来询问之前的操作是否完成。这样的过程其实也叫轮询。

   阻塞、非阻塞、多路IO复用,都是同步IO,异步必定是非阻塞的,所以不存在异步阻塞和异步非阻塞的说法。真正的异步IO需要CPU的深度参与。换句话说,只有用户线程在操作IO的时候根本不去考虑IO的执行全部都交给CPU去完成,而自己只等待一个完成信号的时候,才是真正的异步IO。所以,拉一个子线程去轮询、去死循环,或者使用select、poll、epool,都不是异步。

参考网址:

https://www.zhihu.com/question/19732473

https://www.zhihu.com/question/27965282

http://www.smithfox.com/?e=191

https://zhuanlan.zhihu.com/p/21416728

http://blog.csdn.net/dinglang_2009/article/details/50461697

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
同步非阻塞异步非阻塞都是针对并发编程的不同策略,主要区别在于它们如何管理时间片以及在处理任务时的交互方式。 ### 同步非阻塞 (Synchronous Non-blocking) - **特点**: 系统能持续接收并处理新请求,即便是在处理较长耗时的操作期间也是如此。 - **工作流程**: 接收一个请求后,系统并不等待其完成,而是继续处理其他未完成的请求,并将当前请求放入等待队列中。当当前请求完成或超时时,系统会从等待队列中取出并继续处理。 - **优势**: 提高了并发性能和整体系统利用率。 - **劣势**: 开发和调试相对复杂,尤其是在多任务切换时需要更精细的控制。 ### 异步非阻塞 (Asynchronous Non-blocking) - **特点**: 更侧重于在处理I/O和其他耗时任务时不阻塞主线程或任何其他的任务流。 - **工作流程**: 当遇到I/O操作、数据库查询等需要等待的情况时,程序会立即返回给用户,而不是进入阻塞状态。这使得在等待结果的同时,系统能够处理更多的任务。 - **优势**: 显著提高并发处理能力,特别是面对大量轻量级任务时。 - **劣势**: 需要使用回调函数、事件循环或多路复用器等复杂的机制来组织和管理任务,增加了代码的复杂性和难度。 ### 主要区别总结 - **任务执行顺序与调度**: - **同步非阻塞**:保持任务按接收顺序执行,但在等待耗时操作时,可以并行处理其它任务。 - **异步非阻塞**:任务不受接收顺序限制,一旦遇到耗时操作即返回,直到结果准备好才再次运行。 - **核心目标**: - **同步非阻塞**:主要目标是提高整体系统性能和响应速度。 - **异步非阻塞**:着重于最大化I/O操作的效率,特别是在处理大量I/O密集型任务时。 - **实现方式**: - **同步非阻塞** 可以通过优化现有线程或进程的调度实现,例如通过多线程池、异步文件系统等技术。 - **异步非阻塞** 则更多依赖于事件驱动和回调机制,如通过异步IO、基于事件的网络服务器等技术。 ### 相关问题: 1. **异步编程与同步编程的主要区别是什么?** 2. **异步非阻塞编程在哪些场景下特别有效?** 3. **在选择同步非阻塞还是异步非阻塞时,应考虑哪些因素?** 以上介绍了这两种编程策略的核心差异及其应用场景,选择哪种取决于具体的业务需求、系统负载特性以及团队的技术栈和经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值