天天JAVA:Event Loop模式

本文详细探讨了同步、异步、阻塞和非阻塞的概念,并介绍了Event Loop模式,阐述了操作系统层面的I/O模型演进,包括I/O多路复用的各种实现,如select、poll、epoll和kqueue。同时,文章解释了信号驱动IO和异步IO模型,并结合JavaScript中的Event Loop应用,揭示了事件轮询在处理多任务和异步操作中的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Event Loop模式

什么是同步、异步、阻塞、非阻塞?

  • 如果所有的调用都是立即返回结果,不存在执行等待(I/O通信->执行等待,资源等待->服务挂起),就不需要异步和阻塞。
  • 同步/异步:主要体现在调用方发起请求后,是自己主动探查结果反馈(同步),还是被动由服务提供方告知反馈结果(异步)。
  • 阻塞/非阻塞:主要体现在调用方发起请求后,在等待结果反馈期间,是原地不动(阻塞),还是统筹时间干别的事情去(非阻塞)。
消息通信机制层面理解:同步 or 异步

同步:调用方调用,调用方主动询问。(调用方一会儿一问:“完事没啊?”

异步:调用方调用,返回结果以(回调callback、状态或者通知)方式由服务提供方告知调用方。(调用方:“完事告诉我哈!”

程序调用层面理解:阻塞 or 非阻塞

阻塞:调用方的线程request在等待反馈结果期间被挂起(啥也不干了),调用方得到response,再唤醒被挂起的线程,该唤醒过程可能是服务提供方以回调的方式唤醒的。(调用方:“啥也不干,干等你!”

非阻塞:调用方的线程request在等待结果期间不会被挂起(可以干别的),直到response后才返回。(调用方:“老子忙别的去了!”

  • 同步阻塞I/O:调用方请求后,一直等待结果,不干别的。
  • 同步非阻塞I/O:调用方请求后,一边去吃鸡了(干别的事儿),一边不断询问(完事儿没)。
  • 异步阻塞I/O:调用方请求后,也不干别的,也不询问。服务提供方完成之后,主动告知调用方。
  • 异步非阻塞I/O:调用方请求后,万事大吉,一边去吃鸡了(干别的事儿)。服务提供方完成之后,主动告知调用方。
操作系统层面理解:同步 or 异步,阻塞 or 非阻塞

同步:应用层向系统内核发起请求,不断盲目询问:“完事儿没?”,直到完事儿了。

异步:应用层向系统内核发起请求,走了不管了,系统内核完成操作后主动告知应用层:“完事儿了哈!”

阻塞:应用层向系统内核发起I/O请求,被挂起,盲目傻傻等待,直到完事儿了。

非阻塞:应用层向系统内核发起I/O请求,干别的去了。

操作系统I/O模型演进:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值