33. bio和nio

这篇具有很好参考价值的文章主要介绍了33. bio和nio。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、bio网络模型

1.1 bio网络模型示意图

单个客户端向服务器发起请求时,请求顺序如下:
33. bio和nio,# 9 知识点,nio,bio

多个客户端向一个服务器发起请求时,请求顺序如下:
33. bio和nio,# 9 知识点,nio,bio

1.2 bio网络模型缺点

1.阻塞式I/O

服务器端的线程会因为阻塞I/O,一直阻塞,等待客户端的请求。
若客户端一直不发起,服务端的业务线程会一直存在。

2.弹性伸缩能力差

因为一个客户端对应一个服务端的业务线程,那么客户端和服务端线程数是1比1的关系,再好的机器也难以承受过多的线程。

3.多线程耗费资源

线程的创建销毁、大量的线程存在服务端,服务端的cpu调度资源都会存在影响

二、NIO网络模型

2.1 nio网络模型示意图

单个客户端向服务器发起请求时,请求顺序如下:
33. bio和nio,# 9 知识点,nio,bio

2.2 nio网络模型的改进

1.非阻塞式I/O

nio模型是基于非阻塞式I/O构建出来的,服务器端提供一个单线程的select,统一管理所有客户端接入的socket链接,并负责监听每个链接所关心的事件。

2.弹性伸缩能力强

因为服务端不是多个线程来处理,而是一个线程就可以处理所有请求,所有客户端和服务端线程数是1比N的关系,理论上可以接入无限的请求。

3.单线程节省资源

减少了线程的创建和销毁,以及线程上下文的切换问题。

三、NIO核心- Channel(通道)

3.1 Channel 简介

1.双向性

信息传输的通道,jdk的nio是对输入输出的方式的另一种抽象,类比bio中的流的概念。
不同的是流是单向传输,分输入流输出流。而通道支持双向传输,一个channel既可读又可写。

2.非阻塞性

传统流是阻塞模式,而channel可以工作在非阻塞模式下。

3.操作唯一性

操作channel的唯一方式是buffer,通过buffer操作channel实现数据块的回写

3.2 Channel 实现类

1.文件类 : FileChannel - 对文件进行读写的流 2.UDP类 :DatagramChannel - 用于UDP的数据读写 3.TCP类 : ServerSocketChannel/SocketChannel 基于TCP的数据读写

3.3 bio的socket 和 nio的channel代码实现

bio的socket代码实现逻辑
33. bio和nio,# 9 知识点,nio,bio

nio的channel代码实现逻辑
33. bio和nio,# 9 知识点,nio,bio

四、NIO核心- buffer(缓冲区)

4.1 buffer简介

作用 - 读写channel中的数据或者将数据写到channnel中。
本质 - 一块内存区域。这块内存能读数据,写数据,被nio封装成了一个buffer对象,提供了一系列API。

4.2 buffer属性

1.Capacity:容量 - 表明数组可以容纳多少字节,如果写入的字节数超过最大容量,那么需要清空后,才能继续往里面写入数据。
2.Position: 位置 - position表示当前位置,初始化为0,当一个byte写入后,position会移动到下一个可插入的数据单元。position最大可为容量减1
3.Limit:上限(写模式下) -limit表示最多能往buffer里写入多少数据,此模式下limit等于Capacity。
4.Limit:上限(读模式下) -limit表示最多能从buffer里读多少数据,这时limit会被设置成Position值
5.Mark:标记 - 表示一个特定的position位置,可以通过调用buffer的reset方法恢复到这个position位置。

4.3 buffer的API

1.初始化
33. bio和nio,# 9 知识点,nio,bio

2.写数据
33. bio和nio,# 9 知识点,nio,bio

3.写模式切换为读模式
33. bio和nio,# 9 知识点,nio,bio

4.读取一个字节
33. bio和nio,# 9 知识点,nio,bio

5.设置mark标记
33. bio和nio,# 9 知识点,nio,bio

6.回到标志位
33. bio和nio,# 9 知识点,nio,bio

7.重置属性
33. bio和nio,# 9 知识点,nio,bio

五、NIO核心- Select(选择器)

5.1 简介

1.作用 - I/O就绪选择
2.地位 - NIO网络编程的基础
3.定义 - select是java的nio中能够检测1到多个nio通道,并能够知晓通道是否为诸如读写事件做好准备的组件,通过他,一个单独的线程就可以管理多个channel,从而管理多个链接。

5.2 核心API

33. bio和nio,# 9 知识点,nio,bio

5.3 SelectionKey简介

1.四种就绪状态常量
    connect 连接就绪
    accept  接收就绪
    read    读就绪
    write   写就绪

六、NIO编程实现步骤

33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio

七、总结

33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio
33. bio和nio,# 9 知识点,nio,bio文章来源地址https://www.toymoban.com/news/detail-583926.html

到了这里,关于33. bio和nio的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 竞赛知识点4【搜索】

    栈是限定仅在表头进行插入和删除操作的线性表(先进后出)。 队列是只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。 树是一种数据结构,它是由 n ( n ≥ 1 ) n (ngeq1) n ( n ≥ 1 ) 个有限节点组成一个具有层次关系的集合。把它叫做 “树”是因为

    2024年02月02日
    浏览(24)
  • http相关知识点

    一张网页实际上可能会有多种元素组成,这也就说明了网页需要多次的http请求。 可由于http是基于TCP的,而TCP创建链接是有代价的,因此频繁的创建链接会导致效率降低 为了防止这种情况,就需要两端主机都具备支持长连接的功能,将大份的资源使用一条链接就包含,也就是

    2024年02月13日
    浏览(34)
  • Linux相关知识点

    Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。 Linux内核 是一个Linux系统的内核,而不是一个操作系统 Linux操作系统 红帽操

    2024年02月11日
    浏览(36)
  • 2023面试知识点一

    默认的,新生代 ( Young ) 与老年代 ( Old ) 的比例的值为 1:2 ( 该值可以通过参数 –XX:NewRatio 来指定 ),即:新生代 ( Young ) = 1/3 的堆空间大小。老年代 ( Old ) = 2/3 的堆空间大小。其中,新生代 ( Young ) 被细分为 Eden 和 两个 Survivor 区域,这两个 Survivor 区域分别被命名为 from 和 t

    2024年02月07日
    浏览(27)
  • FPGA基础知识点

    基础知识 逻辑值 逻辑0:表示低电平,也就是对应电路GND 逻辑1:表示高电平,也就是对应电路VCC 逻辑X:表示未知,有可能是高电平也有可能是低电平 逻辑Z:表示高阻态,外部没有激励信号,是一个悬空状态 数字进制格式 Verilog数字进制格式包括 二进制(b) , 八进制(

    2024年02月03日
    浏览(40)
  • ThreadLocal相关知识点

    ThreadLocal是Java中的一个类,它提供了一种线程局部变量的机制。它的作用是,为每个线程创建一个独立的变量副本,各个线程之间互不干扰。简单来说,ThreadLocal为多线程环境下的线程提供了一种线程私有的数据存储方式。 使用ThreadLocal可以避免多线程中的数据共享和竞争条

    2024年02月11日
    浏览(32)
  • Redis相关知识点

    Redis (REmote DIctionary Server) 是用 C 语言开发的一个开源的高性能键值对(key-value)数据库,它支持网络,可基于内存亦可持久化,并提供多种语言的API。Redis具有高效性、原子性、支持多种数据结构、持久化、高并发读写等特点。 特征: 1.数据间没有必然的关联关系 2.内部采用

    2024年01月23日
    浏览(55)
  • 柔性数组知识点

    什么是柔性数组?柔性数组其实也是动态内存管理部分的内容。这节主要来复习柔性数组的知识点。  当结构体的最后一个成员为数组, 且这个数组的大小未确定时, 我们就称它是柔性数组。 如: struct stu {         char name[20];         int age;         char adress[]; } 这里的

    2024年02月22日
    浏览(36)
  • DAC相关知识点

    1.回放数据64bit的数据来源有两个地方: A——ROM波形数据表(数据来源可由dds产生或者matlab产生,本实际项目选择由dds产生的数据:通过写地址出来相应频率的波形)。 B——预留的接口给客户用来回访他们的I/Q数据 (64bit数据一般是4组16bit的IQ拼接的{i0,q0,i1,q1})。 2.6

    2024年02月12日
    浏览(37)
  • MySQL高阶知识点

    1.长度可变性 : varchar类型用于存储可变长度的字符串,比固定长度类型更加节省空间。有一种情况除外:如果MySQL表使用ROW_FORMAT=FIXED创建的话,每一行都会使用定长存储。 char类型用于存储定长字符串。 2.存储方式 varchar需要1或者2个额外字节记录字符串的长度:如果列的最

    2024年02月13日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包