阻塞与非阻塞

阻塞与非阻塞的关系

当前执行流是否被暂停? 如果我们的代码因为调用某些函数而被暂停运行,那么就是阻塞的,如readsleeprecv ,都涉及到系统调用,会释放当前CPU资源。

此时,操作系统会把CPU切换到其他执行流中,当前执行流被暂停,因此发生了阻塞。

比如一个场景:我们知道java代码的执行都是要被转换成二进制流在内存中执行的,比如涉及到读取文件的操作时,文件是存放在磁盘 上的,那么这就涉及系统调用:

read( )函数 ,同时我们知道磁盘的读写速度是远远慢于内存中的,因此cpu也不可能去傻傻等待磁盘读写这一漫长的过程,于是就会暂停当前执行流,这就是阻塞。

执行流:CPU执行一段机器指令(这个机器指令通常是由编译器编译好了的,放在内存中,由CPU执行)

执行流和线程的区别

比如发生上面阻塞的情况:

执行流

执行流会被中断,直到阻塞操作完成之后,CPU分配,执行流继续执行,会恢复到被阻塞的位置。

线程

线程的角度,当前线程从运行态 变为阻塞态,该线程会释放CPU资源,操作系统可以将CPU分配给其他线程或进程。

阻塞与非阻塞的案例

非阻塞调用

public int sum(int a, int b){

return a+b;

}

那如果在进行计算之前调用sleep ()函数,这时sum()的调用就是阻塞的了,因为任何调用sum()函数的线程都会被暂停运行10秒
阻塞调用

public int sum(int a, int b){

Thread.sleep(10)

return a+b;

}

同步阻塞 和 同步非阻塞

同步和阻塞有些相似:不过从编程角度上来看,同步调用不一定是阻塞的,就像上面的加法。
同步不一定是阻塞的,阻塞一定是同步的
异步阻塞 和 异步非阻塞

异步之间代表两者之间是没有任何依赖关系的,因此不存在异步阻塞的情况

异步非阻塞,既然是异步,那么阻塞就和当前上下文没有任何关系了,一般都是异步非阻塞的组合

同步与异步

同步

调用者和被调用者 存在依赖关系 ,调用者必须要等待被调用者正常返回 才可以继续执行下一步的操作
异步

调用者和被调用者之间 没有任何依赖关系,仅仅是将任务发布出去之后然后,立即返回 紧接着执行下一步操作了。程序被编译后变成cpu可以识别的机器指令,cpu执行这些指令表现出来就是程序正在运行。

相关推荐
向阳2562 分钟前
SpringBoot+vue前后端分离整合sa-token(无cookie登录态 & 详细的登录流程)
java·vue.js·spring boot·后端·sa-token·springboot·登录流程
巷北夜未央8 分钟前
Python每日一题(14)
开发语言·python·算法
XiaoLeisj19 分钟前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
风象南20 分钟前
SpringBoot实现数据库读写分离的3种方案
java·spring boot·后端
振鹏Dong27 分钟前
策略模式——本质是通过Context类来作为中心控制单元,对不同的策略进行调度分配。
java·策略模式
ChinaRainbowSea36 分钟前
3. RabbitMQ 的(Hello World) 和 RabbitMQ 的(Work Queues)工作队列
java·分布式·后端·rabbitmq·ruby·java-rabbitmq
雾月5536 分钟前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
Y.O.U..1 小时前
今日八股——C++
开发语言·c++·面试
melck1 小时前
liunx日志查询常用命令总结
java·服务器·网络
守护者1701 小时前
JAVA学习-练习试用Java实现“实现一个Hadoop程序,使用Hive进行复杂查询和数据筛查”
java·学习