同步、异步、阻塞、非阻塞的关系

相关介绍

1、同步与异步:针对调用方而言。调用方是否需要等待返回调用结果。异步不需要等待,可以采用状态通知、回调函数的方式获取结果,以read文件为例

同步方式读取文件:read(filename),直接读取文件,需要等待read方法执行完才能继续运行后续代码

异步方式读取文件:read(filename, callbackFunc),不需要等read方法执行完,可以立马运行后续代码,读取文件完成后会执行回调函数的逻辑

2、阻塞与非阻塞:针对执行方而言。在执行调用时,返回结果前线程是否需要被挂起(线程执行流是否会被暂停),是针对线程来说的。例如sleep(10)、read系统调用会让当前线程阻塞,而 a = b + c不会让线程阻塞。

四者关系

1、同步不一定阻塞。例如下面代码:main函数调用sum方法,main函数需要等到sum的结果才能继续往后执行(表明是同步的),但是sum方法在执行的过程中线程不会被挂起(线程是非阻塞的)

2、以上面的代码为例,构造一个同步阻塞的场景。main函数调用sum方法,main函数需要等到sum的结果才能继续往后执行(表明是同步的),sum方法在执行的过程中遇到sleep会导致线程被挂起,因此是阻塞逻辑

3、异步不一定非阻塞,但由于流程已经异步化了,表示上下游无依赖,因此一般不会出现异步阻塞的代码。如果流程已经异步化了,但是写的代码是阻塞的,纯属脱裤子放屁了(因为异步的优势没发挥出来),经典的异步阻塞代码是RPC的Feature.get()

PS:Java的IO方式

相关推荐
沉默的八哥8 分钟前
Linux中LVM逻辑卷扩容
linux·运维·服务器
退役小学生呀10 分钟前
十一、K8s细粒度权限管理RBAC
linux·docker·云原生·容器·kubernetes·k8s
Cyanto40 分钟前
Spring注解IoC与JUnit整合实战
java·开发语言·spring·mybatis
qq_4338889340 分钟前
Junit多线程的坑
java·spring·junit
gadiaola1 小时前
【SSM面试篇】Spring、SpringMVC、SpringBoot、Mybatis高频八股汇总
java·spring boot·spring·面试·mybatis
写不出来就跑路1 小时前
WebClient与HTTPInterface远程调用对比
java·开发语言·后端·spring·springboot
Cyanto1 小时前
深入MyBatis:CRUD操作与高级查询实战
java·数据库·mybatis
麦兜*2 小时前
Spring Boot 集成Reactive Web 性能优化全栈技术方案,包含底层原理、压测方法论、参数调优
java·前端·spring boot·spring·spring cloud·性能优化·maven
天上掉下来个程小白2 小时前
MybatisPlus-06.核心功能-自定义SQL
java·spring boot·后端·sql·微服务·mybatisplus
网易独家音乐人Mike Zhou2 小时前
【Linux应用】开发板USB共享网络,网线或USB以太网共享网络(局域网连接PC和开发板,实现PC给开发板共享网络,USB通过NDIS驱动共享)
linux·网络·单片机·mcu·物联网·嵌入式·iot