netty 与 同步、异步、阻塞、非阻塞

https://www.aliyun.com/jiaocheng/792562.html

 

所谓同步,就是在c端发出一个功能调用时,在没有得到结果之前,该调用就不返回。但不一定影响我干别的事情,比如传统多线程bio模型

异步: 异步的概念和同步相对。当c端一个异步过程调用发出后,调用者不能立刻得到结果。先返回。实际处理这个调用的部件在完成后,通过状态、通知回调来通知调用者。

阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起

有人也许会把阻塞调用和同步调用等同起来,实际上他是不同的。对于同步调用来说,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已。而阻塞是实实在在的技术线程阻塞

非阻塞 非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会显式技术阻塞当前线程 

 

 

 https://www.v2ex.com/t/475074

而 NIO 是多路复用 IO,他虽然在获取内核的数据时不会阻塞,但是它却会在将内核数据拷贝到用户空间的时候线程阻塞。所以 NIO 是同步非阻塞。

同步非阻塞,同步体现在 selector 轮循判断 channel 是否准备好这个请求是同步请求,系统没结果不会返回,非阻塞体现在轮询这个过程中处理线程不会一直在吊死在一棵树上(一个channel),可以去做其他的事情(其它channel)。 

其实通知你是告诉你内核准备好了,你取数据的时候还是需要将内核中的数据拷贝到用户空间中(即io第二阶段)。这段时间进程是会阻塞的

转载于:https://www.cnblogs.com/silyvin/p/9674402.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值