高并发基础:NIO

一、概念:NIO即New IO,这个库是在JDK1.4中才引入的。NIO和IO有相同的作用和目的,但实现方式不同,NIO主要用到的是块,所以NIO的效率要比IO高很多。
二、NIO和IO的主要区别
NIO和IO的主要区别
三、BIO的缺点
1、产生阻塞行为:receive、accept、connect、read、write。
2、一对一的连接,每连接一个客户端,就需要开启一个线程去处理,当客户端较多的时候,服务器或产生大量的线程,耗费内存。
3、连接建立之后如果不发生任何的操作,就会导致服务器中的这个线程依旧被占用,耗费服务器的资源。
4、无法实现定点操作。
四、NIO的优点
1、非阻塞,提高传输效率
2、一对多的连接:可以用一个或者少量的服务器中的线程来处理大量的请求,从而节省服务器的内存资源
3、即使已经建立连接,只要没有对应的读写事件,那么依然不能够使用服务器来进行处理
4、利用通道实现数据的双向传输
5、因为利用缓冲区来存储数据,所以可以对缓冲区的数据实现定点操作
五、NIO的三大组件
NIO的三大组件

1、Buffer-缓冲区
缓冲区1
缓冲区2
2、Channel-通道
Channel-通道
3、Selector-多路复用选择器
Selector
客户端与服务端特性

附:

	public static void main(String[] args) {

		// 创建缓冲区对象
		// ByteBuffer底层依靠字节数组来存储数据
		ByteBuffer buffer = ByteBuffer.allocate(10);

		// 获取操作位
		System.out.println(buffer.position());
		System.out.println(buffer.capacity());
		System.out.println(buffer.limit());
	}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值