发布于2021-03-14 06:10 阅读(1240) 评论(0) 点赞(13) 收藏(4)
在计算机中,输入 / 输出(即 IO)是指信息处理系统(比如计算机)和外部世界(可以是人或其他信息处理系统)的通信。输入是指系统接收的信号或数据,输出是指从系统发出的数据或信号。由于程序和运行时数据是在内存中驻留,由 CPU 这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘、网络等,就会有 IO 产生。
同步和异步是一种消息通信机制 (synchronous communication/asynchronous communication),关注点在于 被调用者返回
和 结果返回
之间的关系, 描述对象是被调用对象的行为。
# 同步(Synchronous):在发出一个同步调用时,在没有得到结果之前,该调用就不返回,等待返回结果才继续执行后续的操作。
# 异步( Asynchronous):发出调用,直接返回,不关心是否返回结果。异步可以通过状态、回调、 通知调用者结果,可以先去执行其他操作,然后等待通知再回来执行刚才没执行完的操作。
阻塞和非阻塞是一种业务流程处理方式。关注点在于调用发生时 调用者状态
和 被调用者返回结果
之间的关系。 描述的是等待结果时候调用者的状态此时结果可能是同步返回的,也能是异步返回。
# 阻塞( Blocking ):在结果返回之前,当前线程被挂起,后续代码只有在结果返回后才能执行。
# 非阻塞( Nonblocking):在不能立刻获取结果前,该调用不会阻塞当前线程。
实际编程中,通过线程实现进程的同步非阻塞,通过协程实现线程的同步非阻塞。
# 同步阻塞:打电话问老板有没有某书(调用),老板说查一下,让你别挂电话(同步),你一直等待老板给你结果,什么事也不做(阻塞)。
# 同步非阻塞:打电话问老板有没有某书(调用),老板说查一下,让你别挂电话(同步),等电话的过程中你还一边嗑瓜子(非阻塞)。
异步阻塞 - 异步非阻塞
# 异步阻塞:打电话问老板有没有某书(调用),老板说你先挂电话,有了结果通知你(异步),你挂了电话后(结束调用), 除了等老板电话通知结果,什么事情也不做(阻塞)。
# 异步非阻塞:打电话问老板有没有某书(调用),老板说你先挂电话,有了结果通知你(异步),你挂电话后(结束调用),一遍等电话,一遍嗑瓜子。(非阻塞)
5 种 I/O 模型:
IO 模型的具体解释可以参考 linux 五种 IO 模型
原文链接:https://www.cnblogs.com/a609251438/p/13215832.html
作者:php码农的美好生活
链接:http://www.phpheidong.com/blog/article/3350/dbe40d1a72f87da38d63/
来源:php黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 php黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-4
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!