当前位置:首页 > 开发 > 研发管理 > 正文

同步、异步、阻塞、非阻塞

发表于: 2015-07-15   作者:geeksun   来源:转载   浏览:
摘要: 同步、异步、阻塞、非阻塞这几个概念有时有点混淆,在此文试图解释一下。   同步:发出方法调用后,当没有返回结果,当前线程会一直在等待(阻塞)状态。 场景:打电话,营业厅窗口办业务、B/S架构的http请求-响应模式。   异步:方法调用后不立即返回结果,调用结果通过状态、通知或回调通知方法调用者或接收者。异步方法调用后,当前线程不会阻塞,会继续执行其他任务。 实现:

同步、异步、阻塞、非阻塞这几个概念有时有点混淆,在此文试图解释一下。

 

同步:发出方法调用后,当没有返回结果,当前线程会一直在等待(阻塞)状态。

场景:打电话,营业厅窗口办业务、B/S架构的http请求-响应模式。

 

异步:方法调用后不立即返回结果,调用结果通过状态、通知或回调通知方法调用者或接收者。异步方法调用后,当前线程不会阻塞,会继续执行其他任务。

实现:可通知新建一个线程,或调用执行的方法不影响当前线程执行其他的任务。

场景:发短信、写信、写邮件、QQ\微信聊天,网上办电信业务(比如申请信用卡)、node.js

 

同步和异步,关注的是消息通信机制

 

阻塞:当没有结果返回时,线程处于挂起状态(做不了其他事)。

场景:队列(排队进站)、排队办业务

 

非阻塞:当没有结果时,马上返回,定时再去看有没结果。

场景: 网上买火车票时,没订到票时,定时去看有没有火车票。

 

阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态

 

由以上概念分析可知,高性能的服务一定是异步非阻塞的, 比如 node.js、netty。

同步、异步、阻塞、非阻塞

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
最近的传输项目中,性能一直上不去,考虑着项目本身存在的问题,除了编码之外,找来找去也想不出个
简要 阻塞和非阻塞,异步和同步的原理,以及java和linux在这方面的实现原理。 非阻塞和阻塞 java io
同步阻塞IO 在这个模型中,应用程序(application)为了执行这个read操作,会调用相应的一个system
一篇博文的评论里看到的: (此段有待商榷) 同步异步是,一段时间里能不能做多件事情,不能,同步;能
当你发现自己最受欢迎的一篇blog其实大错特错时,这绝对不是一件让人愉悦的事。 《 IO - 同步,异步
在看ACE的过程中,难免对socket的一些特别的api有点质疑,于是不得不求助于unix网络编程,在看的过
关于这几个概念一直比较模糊,查找了一些资料。看到这篇博客讲的很好,特转载过来,向原作者致谢!
当你发现自己最受欢迎的一篇blog其实大错特错时,这绝对不是一件让人愉悦的事。 《 IO - 同步,异步
同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)I
读了林昊的书,有如下关于IO模式的描述: 很早之前就想弄清楚关于IO的一些概念跟原理,今日有时间不
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号