b BIO &NIO &AIO简单入门

本文介绍了Java BIO、NIO和AIO的基本概念和使用,包括时间服务器示例、线程池的弊端、NIO的缓冲区、通道和多路复用器,以及AIO的异步特性。通过代码示例展示了服务器端和客户端的实现,阐述了从阻塞I/O到非阻塞I/O再到异步I/O的演变过程。
摘要由CSDN通过智能技术生成

–> go to 总目录


java的I/O是逐步演进的从原始的BIO到NIO以及1.7以后的NIO 2.0。本街会通过几个示例介绍不同的I/O。

一、JDK的BIO

传统的BIO模型是一个C/S结构,Serversocket负责绑定IP地址,启动监听端口;Socket负责发起连接操作。

时间服务器TimeServer

最简单的IO模型,服务端阻塞式处理连接

在这里插入图片描述
代码联接

遇到的问题

serverHandler 使用 bufferReader获取socket的输入流,预期结果是循环读取完所有的输入,然后进行回应。实际上只会卡死在readline()
在这里插入图片描述
原因
不能直接从流中读取

死循环读会不会像读文件一样主动返回EOF,只能卡死

二、伪异步I/O(线程池)

为了解决简单BIO即来即联,对线程数量无限制的缺陷,可以通过线程池的方式进行改进。

在这里插入图片描述

Runtime.getRuntime().availableProcessors()
链接Runtime.getRuntime()可以获取Jvm的运行实例,availableProcessors可以获取可获得线程数,与cpu的核数有关系。
code
ArrayBlockQueue有界队列

弊端分析

不通socket处理流的速度不同,BIO的问题在于,当某个线程获取I/O后处理缓慢,其余线程只能加入队列中等待。

  1. 服务端处理缓慢

三、NIO

NIO是异步I/O,与socket和serverSocket对应,NIO提供了SocketChannelServerSocketChannel。新类支持阻塞和非阻塞式。

NIO类库介绍

1. 缓冲区buffer

NIO加入缓冲区Buffer对象,与旧库的区别是,在面向流的I/O时,可以把数据直接写入Stream对象中。
NIO的库中所有对象的读写都是用缓冲区处理的:读数据是从缓冲区读,写数据是写入缓冲区。
缓冲区通常是一个数组(ByteBuffer),除此之外还定义了一些其他的操作。

  • ByteBuffer 字节缓冲区 最常用
  • CharBuffer 字符缓冲区
  • ShortBuffer 短型缓冲区
  • IntBuffer 整型缓冲区
  • LongBuffer
  • FloatBuffer
  • DoubleBuffer
    在这里插入图片描述

2. channel 通道

可以进行读写,与Stream的区别是:channel是全双工双向的,一个流只能是(inputStream或outputStream的子类)单向移动,channel既可以读也可以写。
–类继承结构
在这里插入图片描述
自定向下看,前三次都是channel的接口用来定义它的功能。后面是一些具体的功能类

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值