Java NIO 总结: NIO技术基础回顾

news2024/11/10 22:43:40
❃博主首页 : 「码到三十五」 ,同名公众号 :「码到三十五」,wx号 : 「liwu0213」
☠博主专栏 : <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关>
♝博主的话 : 搬的每块砖,皆为峰峦之基;公众号搜索「码到三十五」关注这个爱发技术干货的coder,一起筑基

目录

      • 引言
      • 一、基本概念
        • Channels(通道)
        • Buffers(缓冲区)
        • Selectors(选择器)
      • 二、工作流程与优势
      • 三、NIO与BIO的区别
      • 四、基本使用

引言

随着互联网技术的快速发展,高并发、高性能成为了现代应用程序的追求目标。传统的Java IO(Input/Output)API在处理高并发请求时显得力不从心,无法满足大规模数据处理的需求。而Java NIO(New IO)技术的出现,为开发者提供了更高效、更灵活的IO操作方式,成为处理大规模数据和高并发场景的首选技术。

在这里插入图片描述

一、基本概念

Java NIO是Java 1.4版本引入的一套新的IO API,它提供了非阻塞IO操作的功能,支持面向缓冲区的、基于通道的IO操作。Java NIO的核心组件包括Channels、Buffers和Selectors。
在这里插入图片描述

Channels(通道)

通道是Java NIO中用于数据读写的对象,类似于传统IO中的流。通道支持非阻塞IO操作,并且可以同时进行读写操作。Java NIO中的通道主要有FileChannel、SocketChannel和ServerSocketChannel等。

Buffers(缓冲区)

缓冲区是Java NIO中用于存储数据的内存块,它是NIO中的数据容器。缓冲区本质上是一个数组,可以保存不同数据类型的数据。在NIO中,所有数据的读写都是通过缓冲区来进行的。

Selectors(选择器)

选择器是Java NIO中的一个重要组件,它用于监控多个通道的IO事件。当一个或多个事件发生时,选择器会通知对应的通道进行处理。使用选择器可以实现单线程处理多个通道的IO操作,提高系统的并发性能。

二、工作流程与优势

Java NIO的工作流程主要包括创建通道、创建缓冲区、注册通道、选择就绪通道和处理事件等步骤。与传统IO相比,Java NIO的优势主要体现在以下几个方面:

  1. 非阻塞IO:Java NIO支持非阻塞IO操作,允许线程在等待数据期间执行其他任务,提高了系统的并发处理能力和资源利用率。
  2. 内存管理:Java NIO中的缓冲区可以重复利用,减少了频繁的内存分配和回收,降低了内存消耗。
  3. 可扩展性:Java NIO的基于事件驱动的线程模型可以轻松地处理大量的并发连接,提高了系统的可扩展性。

其工作流程如下:
在这里插入图片描述
在这里插入图片描述

三、NIO与BIO的区别

Java NIO(New IO)和BIO(Blocking IO)是Java中两种不同的I/O处理方式,它们在处理数据传输时有着显著的区别。以下是它们的主要区别:

  1. 数据传输方式
  • BIO:数据从磁盘读取到内核缓冲区,然后再复制到用户空间缓冲区。这个过程是顺序的,意味着在一个操作完成之前,线程可能会被阻塞。
  • NIO:数据直接从磁盘读取到用户空间缓冲区,大大减少了内核空间到用户空间的复制过程,提高了数据传输的效率。
  1. 线程处理方式
  • BIO:是面向流的,并且是同步阻塞的。这意味着线程在等待数据完全传输过来后才能处理数据。
  • NIO:是面向块的(缓冲区),并且是同步非阻塞的。这意味着线程可以在数据传输过程中做其他事情,从而提高了系统的并发性。
  1. 数据传输速度
  • NIO:由于减少了数据从磁盘到用户空间的复制过程,所以它的数据传输速度通常比BIO快。
  1. 选择器(Selectors)
  • NIO:提供了一种机制,称为选择器(Selectors),它可以同时监听多个通道(Channels)的I/O事件,使得一个单独的线程可以管理多个通道,进一步提高了系统的并发性。而BIO没有这样的机制。
  1. 通道(Channels)
  • NIO:在NIO中,所有的输入/输出都是通过通道(Channels)进行的。通道是可以进行读、写操作的流。这使得NIO的处理更加灵活,可以方便地进行双向通信。而BIO是单向的,输入流只能用于读取数据,输出流只能用于写入数据。

总之

与BIO相比,NIO具有更高的数据传输速度、更好的并发性和更灵活的数据处理方式。因此,对于需要处理大量数据或需要高并发I/O操作的场景(如网络编程),NIO通常是一个更好的选择。但是,如果你不需要这些特性,或者你的应用场景更适用于传统的BIO模型,那么使用BIO也是可行的。重要的是根据实际需求和场景选择最合适的I/O模型。

四、基本使用

下面是一个简单的Java NIO编程使用Java NIO进行文件的读写操作:

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.file.Paths;
import java.nio.file.StandardOpenOption;

public class NIOFileExample {
    public static void main(String[] args) {
        try {
            // 打开文件通道
            FileChannel fileChannel = FileChannel.open(Paths.get("example.txt"), StandardOpenOption.READ, StandardOpenOption.WRITE);
            
            // 创建缓冲区
            ByteBuffer buffer = ByteBuffer.allocate(1024);
            
            // 从文件中读取数据到缓冲区
            int bytesRead = fileChannel.read(buffer);
            
            // 切换缓冲区的读写模式
            buffer.flip();
            
            // 从缓冲区读取数据并处理(这里仅打印)
            while (buffer.hasRemaining()) {
                System.out.print((char) buffer.get());
            }
            
            // 清空缓冲区,以便下次使用
            buffer.clear();
            
            // 假设向缓冲区写入一些数据
            buffer.put("Hello, NIO!".getBytes());
            
            // 切换缓冲区的读写模式
            buffer.flip();
            
            // 将缓冲区的数据写入文件
            while (buffer.hasRemaining()) {
                fileChannel.write(buffer);
            }
            
            // 强制将缓冲区的数据写入磁盘
            fileChannel.force(true);
            
            // 关闭通道
            fileChannel.close();
            
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

关注公众号获取更多技术干货 !

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

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

相关文章

k8s集群新增节点

目前集群状态 如K8S 集群搭建中规划的集群一样 Masternode01node02IP192.168.100.100192.168.100.101192.168.100.102OSCent OS 7.9Cent OS 7.9Cent OS 7.9 目前打算新增节点node03 Masternode01node02node03IP192.168.100.100192.168.100.101192.168.100.102192.168.100.1…

Java核心篇之JVM探秘:对象创建与内存分配机制

系列文章目录 第一章 Java核心篇之JVM探秘&#xff1a;内存模型与管理初探 第二章 Java核心篇之JVM探秘&#xff1a;对象创建与内存分配机制 第三章 Java核心篇之JVM探秘&#xff1a;垃圾回收算法与垃圾收集器 第四章 Java核心篇之JVM调优实战&#xff1a;Arthas工具使用及…

Windows11终端winget配置

一、工具安装 Windows11是自带该工具的&#xff0c;如果wind10&#xff0c;可以找应用商店和GitHub上进行下载。 安装地址使用 winget 工具安装和管理应用程序 | Microsoft Learn 发布地址 Releases microsoft/terminal GitHub 二、无法使用问题排错 在命令行界面出现以…

鸿蒙读取本地文件同步,异步的优化问题

一、问题引入 有这样一个业务场景&#xff0c; 在进入一个新页面前&#xff0c;需要读取本地文件 。 当这个文件比较大时 &#xff0c;会造成加载页面时间过长。 二、 问题讲解 一般在页面的aboutToAppear里&#xff0c;我们会同步读取文件 &#xff0c; 因为页面UI 依赖文件…

sql monitoring 长SQL ASH AWR 都没有 未Commit or export to csv

Duration 4小时&#xff0c; Database Time 22.5&#xff0c; Session Inactive&#xff0c; 1.未Commit原因, 2.慢慢导出成csv文件&#xff1f; How is v$session status INACTIVE and v$sql_monitor status EXECUTING concurrently 2641811 Posts: 8 Jan 11, 2016 6:47P…

【Linux】重定向 | 为什么说”一切皆文件?“

目录 前言 1.文件描述符分配规则 2.dup2 重定向接口 3.重定向 3.1>输出重定向 3.2>>追加重定向 3.3<输入重定向 3.4 shell 模拟实现< > 3.5 理解> 4. 理解“Linux 下一切皆文件” 前言 问&#xff1a;fd 为什么默认从 3 开始&#xff0c;而不是…

手机怎么用代理ip上网

在数字化时代&#xff0c;网络已经成为我们生活中不可或缺的一部分。然而&#xff0c;有时候出于安全、隐私或访问特定网络资源的需要&#xff0c;我们可能需要使用代理IP来上网。那么&#xff0c;什么是代理IP&#xff1f;如何在手机上设置并使用它呢&#xff1f;本文将为您详…

聚观早报 | 网宿科技推出边缘AI网关;AMD再收购AI公司

聚观早报每日整理最值得关注的行业重点事件&#xff0c;帮助大家及时了解最新行业动态&#xff0c;每日读报&#xff0c;就读聚观365资讯简报。 整理丨Cutie 7月12日消息 网宿科技推出边缘AI网关 AMD再收购AI公司 谷歌Pixel 9系列将配超声波指纹 三星Galaxy Z Fold6亮相 …

如何写论文的讨论和结论部分,提升审稿通过率300%?(附例句模版)

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 关于论文讨论Discussion部分的撰写&#xff0c;娜姐之前写过几篇文章&#xff1a; 1 Discussion讨论部分被3个审稿人说没深度没逻辑&#xff0c;用这个AI工具三步拯救了我&am…

前端插槽简易版详解【适合有点基础但是有点迷糊的同学查阅】

简易版默认插槽 默认插槽也有自己的名字 效果&#xff1a; 具名插槽 简写 萝卜坑可以种组件哦 插槽传值&#xff1a;父组件用scope接收---变成一个对象

udp协议模拟远程输入指令控制xshell

不了解udp协议的可以先看一下udp协议下的socket函数_udp socket函数-CSDN博客 我之前还写过模拟实现xshell的模拟实现简单的shell-CSDN博客 如今我们要模拟的是让别人连网络连到我们主机&#xff0c;他可以执行命令&#xff1a; 1.接口 我们之前是用execl系列的函数来实现的…

【Android】Service介绍和生命周期

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 介绍 Service是Android程序中四大基础组件之一&#xff0c;它和Activity一样都是Context的子类&#xff0c;只不…

强化学习的数学原理(1)

基本概念 State:在下面的例子中就是指每个位置&#xff08;location&#xff09;&#xff0c;例如s1、s2、s3…就是一个State&#xff0c;所有State的集合就是State Space(集合空间 S { s1,s2,s3,s4,s5…,s9 }) Action:每个状态可采取的行动&#xff0c;就如下面图片的例子&a…

openEuler 安装 podman 和 podman compose

在 openEuler 22.03 LTS SP4 中&#xff0c;你可以使用 dnf 包管理器来安装 Podman 和 Podman Compose。openEuler 默认使用 dnf 作为包管理器&#xff0c;所以这是安装软件的首选方式。 关于 openEuler 22.03 LTS SP4 下载地址&#xff1a; https://www.openeuler.org/zh/dow…

昇思MindSpore 25天学习打卡营|day20

GAN图像生成 模型简介 生成式对抗网络(Generative Adversarial Networks&#xff0c;GAN)是一种生成式机器学习模型&#xff0c;是近年来复杂分布上无监督学习最具前景的方法之一。 最初&#xff0c;GAN由Ian J. Goodfellow于2014年发明&#xff0c;并在论文Generative Adve…

Java中HashMap详解:hash原理、扩容机制、线程不安全及源码分析

前言 HashMap 是 Java 中常用的数据结构之一&#xff0c;用于存储键值对。在 HashMap 中&#xff0c;每个键都映射到一个唯一的值&#xff0c;可以通过键来快速访问对应的值&#xff0c;算法时间复杂度可以达到 O(1)。 HashMap 的实现原理是基于哈希表的&#xff0c;它的底层是…

Java语言程序设计——篇四(1)

类和对象 面向对象概述面向过程与面向对象面向对象基本概念面向对象的基本特征面向对象的优势及应用 为对象定义类类的修饰符成员变量成员变量-修饰符 构造方法⭐️成员方法成员方法-修饰符例题讲解 ⚠️理解栈和堆 面向对象概述 两种程序设计方法 结构化程序设计&#xff0c…

方波的傅里叶变换及方波的MATLAB实现

一、傅里叶变换简介 傅里叶变换&#xff0c;表示能将满足一定条件的某个函数表示成三角函数&#xff08;正弦和/或余弦函数&#xff09;或者它们的积分的线性组合。傅里叶变换是一种线性的积分变换。它的理论依据是&#xff1a;任何连续周期信号都可以由一组适当的正弦曲线组合…

Mac安装stable diffusion 工具

文章目录 1.安装 Homebrew2.安装 stable diffusion webui 的依赖3.下载 stable diffusion webui 代码4.启动 stable diffusion webui 本体5.下载模型6.这里可能会遇到一个clip-vit-large-patch14报错 参考&#xff1a;https://brew.idayer.com/install/stable-diffusion-webui/…

Unity 优化合集

1️⃣ 贴图优化 1. Read/Write Enable 这个属性勾选后允许你在运行时读取和写入纹理数据&#xff0c;这对于需要实时生成内容或者需要动态修改纹理的场合非常有用但在大部分情况下这是不必要的。如果打开这个属性&#xff0c;会使运行时贴图大小翻倍&#xff0c;内存中会额外…