多线程实战(四)——快速理解同步异步以及阻塞非阻塞
2016-11-26 17:44
501 查看
总是觉得模棱两可,今天看到一段话觉得简单明了,摘录下来:
老张爱喝茶,废话不说,煮开水。
出场人物:老张,水壶两把(普通水壶,简称水壶;会响的水壶,简称响水壶)。
1 老张把水壶放到火上,立等水开。(同步阻塞)
老张觉得自己有点傻
2 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞)
老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
3 老张把响水壶放到火上,立等水开。(异步阻塞)
老张觉得这样傻等意义不大
4 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞)
老张觉得自己聪明了。
所谓同步异步,只是对于水壶而言。
普通水壶,同步;响水壶,异步。
虽然都能干活,但响水壶可以在自己完工之后,提示老张水开了。这是普通水壶所不能及的。
同步只能让调用者去轮询自己(情况2中),造成老张效率的低下。
所谓阻塞非阻塞,仅仅对于老张而言。
立等的老张,阻塞;看电视的老张,非阻塞。
情况1和情况3中老张就是阻塞的,媳妇喊他都不知道。虽然3中响水壶是异步的,可对于立等的老张没有太大的意义。所以一般异步是配合非阻塞使用的,这样才能发挥异步的效用。
——来源网络,作者不明。
找到一条总结的挺好的评论,确实上面说的有些缺陷,但是贵在明了
同步就是烧开水,要自己来看开没开;异步就是水开了,然后水壶响了通知你水开了。阻塞是烧开水的过程中,你不能干其他事情(即你被阻塞住了);非阻塞是烧开水的过程里可以干其他事情。同步与异步说的是你获得水开了的方式不同。阻塞与非阻塞说的是你得到结果之前能不能干其他事情。两组概念描述的是不同的内容。
老张爱喝茶,废话不说,煮开水。
出场人物:老张,水壶两把(普通水壶,简称水壶;会响的水壶,简称响水壶)。
1 老张把水壶放到火上,立等水开。(同步阻塞)
老张觉得自己有点傻
2 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞)
老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
3 老张把响水壶放到火上,立等水开。(异步阻塞)
老张觉得这样傻等意义不大
4 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞)
老张觉得自己聪明了。
所谓同步异步,只是对于水壶而言。
普通水壶,同步;响水壶,异步。
虽然都能干活,但响水壶可以在自己完工之后,提示老张水开了。这是普通水壶所不能及的。
同步只能让调用者去轮询自己(情况2中),造成老张效率的低下。
所谓阻塞非阻塞,仅仅对于老张而言。
立等的老张,阻塞;看电视的老张,非阻塞。
情况1和情况3中老张就是阻塞的,媳妇喊他都不知道。虽然3中响水壶是异步的,可对于立等的老张没有太大的意义。所以一般异步是配合非阻塞使用的,这样才能发挥异步的效用。
——来源网络,作者不明。
找到一条总结的挺好的评论,确实上面说的有些缺陷,但是贵在明了
同步就是烧开水,要自己来看开没开;异步就是水开了,然后水壶响了通知你水开了。阻塞是烧开水的过程中,你不能干其他事情(即你被阻塞住了);非阻塞是烧开水的过程里可以干其他事情。同步与异步说的是你获得水开了的方式不同。阻塞与非阻塞说的是你得到结果之前能不能干其他事情。两组概念描述的是不同的内容。
相关文章推荐
- 微软BI 之SSIS 系列 - 理解Data Flow Task 中的同步与异步, 阻塞,半阻塞和全阻塞以及Buffer 缓存概念
- 快速理解异步/同步 与 阻塞/非阻塞
- python之多进程和多线程以及同步异步阻塞
- 概念理解之同步,异步,阻塞,非阻塞
- IO模型介绍以及同步异步阻塞非阻塞的区别
- 怎样理解阻塞非阻塞与同步异步的区别?
- 阻塞、非阻塞、异步、同步以及select/poll和epoll
- 阻塞/非阻塞/同步/异步方法和多线程的关系?没有任何关系,俩不挨着
- 阻塞、非阻塞、异步、同步以及select/poll和epoll
- 同步与异步、阻塞与非阻塞的理解
- 转载:关于多线程,并发、并行、同步、异步的理解
- TCP同步与异步及阻塞模式,多线程+阻塞模式,非阻塞模式简单介绍
- 网络IO模型及同步、异步与阻塞、非阻塞的理解
- 并发 并行 同步 异步 多线程 阻塞 非阻塞
- IO的阻塞与非阻塞、同步与异步以及Java网络IO交互方式
- 知乎上对理解阻塞非阻塞与同步异步的有趣解释
- 并发,同步,异步,互斥,阻塞,非阻塞的理解
- 关于[同步异步]和[阻塞非阻塞]的个人理解
- 阻塞、非阻塞、异步、同步以及select/poll和epoll
- 同步/异步、阻塞/非阻塞的理解