02. 进程的同步、异步和阻塞、非阻塞

一、同步、异步

1.1 同步

所谓同步,就是在发出一个功能调用时,在没有得到结果前,该调用就不会返回

按这个定义,其实大部分函数都是同步调用的,但是一般我们在说同步/异步的时候,特指那些需要其他部件协作或则需要一定时间完成的任务

1.2 异步

异步的概念和同步相对,当一个异步功能调用发出后,调用者不能立刻得到结果

当该异步功能完成后,通过状态、通知或者回调来通知调用者。
如果异步功能用状态来通知,那么调用者就需要每隔一段时间检查一次,效率就很低;
如果使用通知的方式,效率就很高,因为异步功能几乎不需要做额外的操作;
至于回调函数,其实和通知没太大区别

二、阻塞、非阻塞

2.1 阻塞

阻塞调用是指 在调用结果返回之前,当前线程会被挂起(例如遇到IO操作),
函数只有在得到结果之后才会将阻塞的线程激活,

与同步不能混为一谈,对于同步调用来说,很多时候当前线程还是激活的,只是逻辑上当前函数没有返回而已(可能是在等IO,也有可能是在等计算结果)
例如:

同步调用一个一万次的任务,该调用会一直等待,直到任务返回结果为止,但是并未阻塞(即便是被抢走了CPU的使用权限,那也是处于就绪态,CPU执行权限一回来就能立马进入运行态)
阻塞调用:例如 当socket工作在阻塞模式的时候,如果在没有数据的情况下调用recv函数,那么当前线程就会被挂起,直到有数据为止

2.2 非阻塞

非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前也会立刻返回,
同时该函数不会阻塞当前线程。

2.3 小结

一、同步与异步针对的是函数/任务的调用方式:

① 同步就是当一个进程发起一个函数(任务)调用的时候,一直等到函数(任务)完成,而进程继续处于激活状态。
② 而异步情况下是当一个进程发起一个函数(任务)调用的时候,不会等函数返回,而是继续往下执行,
	函数返回的时候通过状态、通知、事件等方式通知进程任务完成。

二、阻塞与非阻塞针对的是进程或者线程

阻塞是当请求不能满足的时候 就将进程挂起
非阻塞则不会阻塞当前进程
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值