【JavaSE】Java基础语法(四十二):NIO

news2025/1/13 3:34:38

文章目录

  • 1. 概述
  • 2. NIO与BIO的区别
  • 3. NIO三大模块
  • 4. NIO创建缓冲区对象【应用】
  • 5. NIO缓冲区添加数据【应用】
  • 6. NIO缓冲区获取数据【应用】
  • 7. 小结


在这里插入图片描述

1. 概述

  • BIO
    Blocking IO,阻塞型IO
  • NIO
    No Blocking IO,非阻塞型IO
  • 阻塞IO的弊端
    在等待的过程中,什么事也做不了
  • 非阻塞IO的好处
    不需要一直等待,当一切就绪了再去做

2. NIO与BIO的区别

  • 区别一
    BIO是阻塞的,NIO是非阻塞的
  • 区别二
    BIO是面向流的,NIO是面向缓冲区的
    BIO中数据传输是单向的,NIO中的缓冲区是双向的

3. NIO三大模块

  • 缓冲区
    用来存储数据
  • 通道
    用来建立连接和传输数据
  • 选择器
    监视通道状态

在这里插入图片描述


4. NIO创建缓冲区对象【应用】

  • 方法介绍
    在这里插入图片描述

  • 代码示例

    public class CreateByteBufferDemo1 {
    	public static void main(String[] args) {
    		//method1();
    		//method2();
    		ByteBuffer wrap = ByteBuffer.wrap("aaa".getBytes());
    		for (int i = 0; i < 3; i++) {
    			System.out.println(wrap.get());
    		}
    	}
    	
    	private static void method2() {
    		byte [] bytes = {97,98,99};
    		ByteBuffer byteBuffer2 = ByteBuffer.wrap(bytes);
    		//缓冲区的长度3
    		//缓冲区里面的内容就是字节数组的内容.
    		for (int i = 0; i < 3; i++) {
    			System.out.println(byteBuffer2.get());
    		}
    		System.out.println(byteBuffer2.get());
    	}
    	
    	private static void method1() {
    		ByteBuffer byteBuffer1 = ByteBuffer.allocate(5);
    		//get
    		for (int i = 0; i < 5; i++) {
    			System.out.println(byteBuffer1.get());
    		}
    		System.out.println(byteBuffer1.get());
    	}
    }
    

5. NIO缓冲区添加数据【应用】

  • 方法介绍
    在这里插入图片描述

  • 代码示例

    public class ByteBufferDemo2 {
    	public static void main(String[] args) {
    		// int position() 当前要操作的索引
    		// int limit() 最多能操作到哪个索引
    		// int capacity() 缓冲区的总长度
    		ByteBuffer byteBuffer = ByteBuffer.allocate(10);
    		System.out.println(byteBuffer.position());//0
    		System.out.println(byteBuffer.limit());//10
    		System.out.println(byteBuffer.capacity());//10
    		// put(byte b) 一次添加一个字节
    		// byteBuffer.put((byte) 97);
    		// System.out.println(byteBuffer.position());
    		// System.out.println(byteBuffer.limit());
    		// System.out.println(byteBuffer.capacity());
    		// put(byte[] src) 一次添加一个字节数组
    		// byteBuffer.put("aaa".getBytes());
    		// System.out.println(byteBuffer.position());//3
    		// System.out.println(byteBuffer.limit());//10
    		// System.out.println(byteBuffer.capacity());//10
    		// position(int newPosition) 修改position
    		// byteBuffer.position(1);
    		// limit(int newLimit) 修改limit
    		// byteBuffer.limit(5);
    		// System.out.println(byteBuffer.position());
    		// System.out.println(byteBuffer.limit());
    		// System.out.println(byteBuffer.capacity());
    		// int remaining() 还有多少能操作
    		// boolean hasRemaining() 是否还有能操作的
    		byteBuffer.put("0123456789".getBytes());
    		System.out.println(byteBuffer.remaining());
    		System.out.println(byteBuffer.hasRemaining());
    	}
    }
    

6. NIO缓冲区获取数据【应用】

  • 方法介绍
    在这里插入图片描述

  • 代码示例

public class ByteBufferDemo3 {
	public static void main(String[] args) {
		ByteBuffer byteBuffer = ByteBuffer.allocate(10);
		byteBuffer.put("abc".getBytes());
		// flip() 切换读写模式(写读)
		byteBuffer.flip();
		// get() 读一个字节
		// while(byteBuffer.limit() != byteBuffer.position()){
		// System.out.println((char) byteBuffer.get());
		// }
		for (int i = 0; i < byteBuffer.limit(); i++) {
		System.out.println((char) byteBuffer.get());
		}
		// get(byte[] dst) 读多个字节
		// byte [] bytes = new byte[byteBuffer.limit()];
		// byteBuffer.get(bytes);
		// System.out.println(new String(bytes));
		// get(int index) 读指定索引的字节
		// System.out.println((char) byteBuffer.get(0));
		// rewind() 将position设置为0,可以重复读
		// byteBuffer.rewind();
		// for (int i = 0; i < byteBuffer.limit(); i++) {
		// System.out.println((char) byteBuffer.get());
		// }
		// clear() 数据读写完毕(读->写)
		byteBuffer.clear();
		byteBuffer.put("qqq".getBytes());
		// array() 将缓冲区转换成字节数组返回
		byte[] bytes = byteBuffer.array();
		System.out.println(new String(bytes));
	}
}

7. 小结

1. 需求:我要把数据写到缓冲区中。
数据是从外面进入到缓冲区的,所以缓冲区在做读数据的操作。

2. 需求:我要把数据从缓冲区中读出来。
数据是从缓冲区里面到外面的。所以缓冲区在做写数据的操作。

3. capacity:容量(长度)
limit: 界限(最多能读/写到哪里)
posotion:位置(读/写哪个索引)

  1. 获取缓冲区里面数据之前,需要调用flip方法

  2. 再次写数据之前,需要调用clear方法,
    但是数据还未消失,等再次写入数据,被覆盖了才会消失。


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/598417.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【正点原子STM32连载】 第二十三章 电容触摸按键实验 摘自【正点原子】STM32F103 战舰开发指南V1.2

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第二十…

Java网络开发(Tomcat)—— 登陆 和 注册功能 的实现 和 迭代升级

目录 引出登陆功能---从html到jsp1.登陆--用post请求2.用html文件的form表单登陆&#xff08;1&#xff09;index.html页面&#xff08;2&#xff09;login.html登陆的页面&#xff08;3&#xff09;LoginServlet.java处理输入信息的代码&#xff08;4&#xff09;登陆成功&…

分布式事务一 事物以及分布式事物介绍

一 事务简介 事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。在关系数据库中&#xff0c;一个事务由一组SQL语句组成。事务应该具有4个属性&#xff1a;原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。 原子性&#xff08;at…

MyBatis - Spring Boot 集成 MyBatis

文章目录 1.版本要求2.导入依赖3.自动配置2.可配置项 MyBatis-Spring-Boot-Starter 可以帮助你更快地在 Spring Boot 之上构建 MyBatis 应用。通过使用该模块我们能够快速实现以下目的&#xff1a; 构建单体应用程序将几乎不需要样板配置使用更少的 XML 配置 1.版本要求 MyB…

Apache Kafka - 构建数据管道 Kafka Connect

文章目录 概述主要概念ConnectorTasksWorkesConvertersTransformsDead Letter Queue 主要使用场景主要价值Kafka Connect API vs Producer 和 Consumer API构建数据管道时需要考虑的主要问题ETL VS ELT数据整合方式的不同ETL 和 ELT 各有优缺点: 概述 Kafka Connect 是一个工具…

Linux二——Web基础与HTTP协议

Web基础与HTTP协议 一、Web基础1. 域名的概念2.域名空间结构3.域名注册4.网页的概念5. HTML概念6.网页基本标签1 二、HTTP协议1.HTTP概念2.HTML的基本标签3.头标签中常用标签4.内容标签中常用的标签 三、动态网页与静态网页1.静态网页2.动态网页3.动态网页和静态网页的区别4.动…

软件测试目的是什么?软件测试公司可提供哪些测试服务类型?

随着科技的不断发展&#xff0c;软件行业的发展也越来越迅速。然而&#xff0c;随着软件的增多和复杂性的提高&#xff0c;开发者们需要更多的手段来确保软件质量。软件测试就是通过一系列的测试来发现软件的问题&#xff0c;从而提高软件的质量。 一、软件测试目的是什么? …

Unity中的UniTask如何取消指定的任务或所有的任务

今天儿童节&#xff0c;犬子已经9个多月了&#xff0c;今天是他的第一个儿童节。中年得子&#xff0c;其乐无穷无尽啊… 〇、 示例效果 一连创建5个异步任务[id 从0~4]&#xff0c;先停止其中的第id 4的任务&#xff0c;再停止所有的任务 一、CancellationTokenSource有什…

利用矩阵分解实现图像压缩(实验)

机器学习的课程&#xff0c;老师布置了一个实验报告&#xff0c;当我看到实验内容&#xff0c;傻眼了&#xff0c;手写计算矩阵特征值和特征向量的函数&#xff0c;这给我整无语了&#xff0c;直接调用已有的不好吗&#xff0c; 我直接摆烂。 实验报告放这了&#…

【C#图解教程】 第六章 方法(上)

方法的结构 方法是一块具有名称的代码&#xff0c;在类和结构中都经常用到 局部变量 局部变量位于方法内部&#xff0c;在方法中声明时产生&#xff0c;在方法执行结束时结束 类型推断与var关键字 某些情况下&#xff0c;在声明的开始部分包含类型名是多余的&#xff0c;因为…

Python-python判断语句:布尔类型和比较运算符、if语句的基本格式、if else语句、if el if else语句、判断语句的嵌套、实战案例

版本说明 当前版本号[20230601]。 版本修改说明20230601初版 知识总览图 目录 文章目录 版本说明知识总览图目录Python判断语句布尔类型和比较运算符布尔类型布尔类型的定义 比较运算符 if语句的基本格式if判断语句if语句的注意点 if else 语句语句注意点 if elif else语句注…

7min 到 40s:SpringBoot 优化居然可以玩出这么多花样!

0 背景 公司 SpringBoot 项目在日常开发过程中发现服务启动过程异常缓慢&#xff0c;常常需要6-7分钟才能暴露端口&#xff0c;严重降低开发效率。通过 SpringBoot 的 SpringApplicationRunListener 、BeanPostProcessor 原理和源码调试等手段排查发现&#xff0c;在 Bean 扫描…

“灵巧小工具”一个将图片处理成打印纸尺寸的丰富功能完全免费无水印的图片处理工具

今天推荐一款微信小程序“灵巧小工具”&#xff0c;经常有打印图片需求的用户赶紧收藏了。 可以先扫码体验一番&#xff1a; 下面介绍一下它的主要功能&#xff1a; 1.照片&#xff08;1寸、2寸、5寸、6寸&#xff09; 支持1寸&#xff0c;2寸照片自动排版&#xff0c;生成相纸…

JavaSE】Java基础语法(四十):UDP通信程序

文章目录 1. UDP发送数据2. UDP接收数据【应用】3. UDP通信程序练习【应用】4. UDP三种通讯方式 1. UDP发送数据 Java中的UDP通信 UDP协议是一种不可靠的网络协议&#xff0c;它在通信的两端各建立一个Socket对象&#xff0c;但是这两个 Socket只是发送&#xff0c;接收数据的对…

IPv6 6to4隧道配置和验证实验

IPv6 6to4隧道配置和验证实验 【实验目的】 熟悉IPv6 6to4隧道的概念。 掌握IPv6和IPv4共存的实现方法。 掌握IPv6 6to4地址编址规则。 掌握IPv6 6to4隧道的配置。 验证配置。 【实验拓扑】 设备参数如下表所示。 设备 接口 IP地址 子网掩码 默认网关 R1 S0/0 19…

cuda编程学习——CUDA共享内存性能优化(九)

前言 参考资料&#xff1a; 高升博客 《CUDA C编程权威指南》 以及 CUDA官方文档 CUDA编程&#xff1a;基础与实践 樊哲勇 文章所有代码可在我的GitHub获得&#xff0c;后续会慢慢更新 文章、讲解视频同步更新公众《AI知识物语》&#xff0c;B站&#xff1a;出门吃三碗饭 …

绝不可错过!R语言与ggplot2实现SCI论文数据分析神器

一、介绍 1.1 R语言和ggplot2 语言是一种强大的数据分析和统计建模工具&#xff0c;具有广泛的应用领域。 ggplot2是基于R语言的数据可视化工具&#xff0c;具有强大的绘图功能和灵活性。 1.2 数据分析中的重要性 R语言和ggplot2在数据分析中具有广泛的应用&#xff0c;能够帮助…

有些香港云主机为啥更容易遭遇停机风险?

​对于搭建过外贸网站的站长们来说&#xff0c;在面对香港云主机的选择时&#xff0c;往往遇到且出现较为频繁的两个词便是&#xff1a;免费香港云主机和付费香港云主机。其中&#xff0c;一些所谓的免费香港云主机&#xff0c;尤其是长久免费使用&#xff0c;恐怕用户们就要承…

ES6中函数新增了哪些扩展?

参数 &#x1f355;&#x1f355;&#x1f355;ES6允许为函数的参数设置默认值 函数的形参是默认声明的&#xff0c;不能使用let或const再次声明 function foo(x5){let x 1;//errconst x 2;//err }参数默认值可以与解构赋值的默认值结合起来使用 function foo({x,y 5}){co…

华为OD机试真题B卷 Java 实现【分奖金】,附详细解题思路

一、题目描述 公司老板做了一笔大生意&#xff0c;想要给每位员工分配一些奖金&#xff0c;想通过游戏的方式来决定每个人分多少钱。按照员工的工号顺序&#xff0c;每个人随机抽取一个数字。按照工号的顺序往后排列&#xff0c;遇到第一个数字比自己数字大的&#xff0c;那么…