网络编程知识杂烩

这篇文章主要记录一些我个人在学习和项目中,遇到的比较基础的一些知识点,方便自己和大家查看。我将会不断完善更新。
--------------------------------------------------------------------分割线---------------------------------------------------------------------------

阻塞和非阻塞——线程访问资源,对该资源是否准备就绪的一种处理方式
阻塞:线程一直等待资源处理完毕,返回结果。

非阻塞:线程不等待资源处理完毕,他会去请求别的资源。

同步和异步——访问数据的一种机制
同步:主动请求并等待IO通知。

异步:主动请求后处理其他任务,结果通过异步通知逐个返回。

BIO (Block IO)
同步阻塞IO。IO进行读写时,线程被阻塞无法做其他操作,是一种传统简单的模式,但是并发处理能力比较低。并且线程之间访问资源耗时较久,比较依赖网速和带宽。JDK1.4之前都是使用BIO。比如:上厕所的时候,厕所满了,我们主动观察等待空位留出,等有人出来时就去占坑。这就是一种BIO。

NIO (Non-Block IO / New IO)
同步非阻塞IO。Selector主动轮询Channel, 哪一个Channel就绪,Selector就进行相应的请求处理。NIO是JDK1.4之后出现的。比如:上厕所的时候,厕所满了,我们出去抽根烟或者玩会手机,时不时的回厕所看一下,有坑留出的话就去占坑。这就是一种NIO。

AIO (NIO 2.0)
异步非阻塞IO。还是上厕所的例子:和BIO不一样的是,在我们出去抽根烟或者玩会手机的时候,有人释放完坑回来主动通知我们。这就是一种AIO。

异步阻塞IO在平时开发中几乎用不到。即等坑时什么都不干,等有人好后再来通知你。
同步-主动看,
异步-被通知。

常见面试题:

  • BIO,NIO,AIO 的区别是什么?
  • 什么是同步阻塞BIO?
  • 什么是同步非阻塞NIO?
  • 什么是异步非阻塞AIO?

==============
Java单例详细说明:https://www.cnblogs.com/zhaoyanjun/p/5652930.html

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值