Java中BIO、NIO、AIO详解

参考:
https://blog.csdn.net/s2152637/article/details/98777686
https://blog.csdn.net/bigorsmallorlarge/article/details/137292669

1、几个基本概念

  • Java中IO模型简介

在Java中,主要有三种IO模型,分别是:

  • 同步阻塞IO(BIO)
  • 同步非阻塞IO(NIO)
  • 异步IO(AIO)
  • 同步与异步
  • 同步:同步就是发起一个调用后,被调用者未处理完请求之前,调用不返回。
  • 异步:异步就是发起一个调用后,立刻得到被调用者的回应表示已接收到请求,但是被调用者并没有返回结果,此时我们可以处理其他的请求,被调用者通常依靠事件,回调等机制来通知调用者其返回结果。
  • 同步和异步的区别最大在于异步的话调用者不需要等待处理结果,被调用者会通过回调等机制来通知调用者其返回结果。
  • 阻塞和非阻塞
  • 阻塞: 阻塞就是发起一个请求,调用者一直等待请求结果返回,也就是当前线程会被挂起,无法从事其他任务,只有当条件就绪才能继续。
  • 非阻塞:非阻塞就是发起一个请求,调用者不用一直等着结果返回,可以先去干其他事情。

注意:

Java 中的 BIO、NIO和 AIO 理解为是 Java 语言对操作系统的各种 IO 模型的封装。
Java中提供的IO有关的API,在文件处理的时候,其实依赖操作系统层面的IO操作实现的

2、BIO(Blocking IO)

  • 同步阻塞:BIO是同步阻塞的,意味着每当有一个IO操作发生时,线程都会被阻塞,直到操作完成。
  • 面向流:BIO面向流进行数据读写,数据处理通常在单个线程中完成。
  • 性能问题:对于大量的并发请求,BIO会因为每个请求都需要独立的线程而性能受限。

同步阻塞I/O模式,数据的读取写入必须阻塞在一个线程内等待其完成。
Java中的BIO分为两种:

  • 1、传统 BIO:一请求一应答
  • 2、伪异步 IO:通过线程池固定线程的最大数量,防止资源的耗费。

在活动连接数不是特别高(小于单机1000)的情况下,这种模型是比较不错的,可以让每一个连接专注于自己的 I/O 并且编程模型简单,也不用过多考虑系统的过载、限流等问题。线程池本身就是一个天然的漏斗,可以缓冲一些系统处理不了的连接或请求。但是,当面对十万甚至百万级连接的时候,传统的 BIO 模型是无能为力的。因此,我们需要一种更高效的 I/O 处理模型来应对更高的并发量。

3、NIO(Non-blocking IO)

NIO是一种同步非阻塞的I/O模型,在Java 1.4 中引入了NIO框架,对应 java.nio 包,提供了 Channel , Selector,Buffer等抽象。

  • 异步非阻塞:NIO是异步非阻塞的,允许一个线程处理多个IO操作,因此在高并发环境下性能更好。
  • 面向缓冲区:NIO使用缓冲区进行数据操作,可以一次性读取或写入大量数据。
  • 多线程支持:NIO可以通过多线程来提高性能,它可以很方便地实现多线程环境下的大量数据处理。

NIO的优势

  • 线程模型:NIO使用多线程模型,可以显著提高IO密集型应用的性能。
  • 非阻塞操作:允许线程在等待IO操作完成时进行其他任务,提高了资源利用率。
  • 面向缓冲区:通过使用缓冲区,NIO可以减少系统调用次数,提高数据处理效率。
  • 选择器:NIO中的选择器允许一个线程监控多个通道的IO事件,从而简化了多路复用。

NIO适用于以下场景

  • 高并发服务器:如Web服务器、应用服务器等,需要处理大量并发请求。
  • 大数据处理:如文件系统的读写操作,需要高效地处理大量数据。
  • 网络编程:特别是在需要使用多路复用的场景,例如实现一个高效的TCP/UDP服务器。

总的来说,NIO提供了比BIO更高效的IO处理方式,特别是在处理大量并发请求和高并发场景下。通过使用缓冲区和选择器,NIO能够减少线程阻塞和系统调用次数,从而提高了性能和资源利用率。

在高并发应用中实现NIO通常涉及到使用Java的java.nio包中的类和接口。以下是一些关键的步骤和组件,它们帮助你在高并发应用中实现NIO:

  • 缓冲区(Buffers):
    使用缓冲区来减少系统调用和提高数据处理效率。例如,ByteBuffer、CharBuffer、DoubleBuffer等。

  • 通道(Channels):
    通道是NIO中用于IO操作的对象,它们提供了一个非阻塞的方式来读写数据。常用的通道有FileChannel、SocketChannel和ServerSocketChannel。

  • 选择器(Selectors):
    选择器用于监控多个通道的IO事件,如连接接入、数据读取等。一个线程可以使用一个选择器来处理多个通道。

  • 多线程:
    在高并发应用中,通常需要使用多个线程来处理不同的通道和任务。

  • 事件驱动编程:
    NIO采用事件驱动的方式来进行IO操作,这使得线程可以在等待IO操作完成时进行其他任务。

4、AIO (Asynchronous I/O)

AIO 也就是 NIO 2。在 Java 7 中引入了 NIO 的改进版 NIO 2,它是异步非阻塞的IO模型。异步 IO 是基于事件和回调机制实现的,也就是应用操作之后会直接返回,不会堵塞在那里,当后台处理完成,操作系统会通知相应的线程进行后续的操作。

注意:

只有AIO是异步操作,BIO和NIO都是同步操作。

有人会提问,NIO不是在缓冲区存放数据吗?所以不应该是异步操作吗?
我们把读写数据分成两部分,第一部分为数据准备,即读写数据之前需要创建各种相关的对象,还要提供数据。第二部分为数据拷贝,即通过输入输出流读写数据或者通过通道想缓冲取读写数据。
NIO只是再第一部分数据准备阶段是异步操作,在数据拷贝阶段还是同步操作的。所以总的来说NIO还是同步操作,因此才叫同步非阻塞IO。

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

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

相关文章

视频合成渲染服务解决方案,数字人+PPT+视频云剪辑

在金融理财领域,一个生动、直观、专业的视频,往往能够在海量信息中脱颖而出,帮助客户更好地理解产品、把握市场动态。然而,传统的视频制作方式往往周期长、成本高、难以适应快速变化的市场需求。 美摄科技,作为行业领…

XZ后门故事:初始分析

2024年3月29日,Openwall OSS安全邮件列表上的一条消息“炸醒”了整个信息安全、开源和Linux社区:XZ出现了一个CVSS评分10.0的恶意后门。 这个后门库的特殊危险在于OpenSSH服务器进程sshd使用它。在多个基于systemd的发行版上(包括Ubuntu、De…

从根源解决问题:构建体系化BOM管理机制与解决方案

BOM(物料清单)是设计与生产间的纽带,其准确及时对企业的竞争力至关重要。然而,维护BOM数据时,常遇到录入错误、信息孤岛及跨部门沟通障碍等难题,直接影响生产效率和成本。为此,道合顺将探讨确保…

Hi3861 OpenHarmony嵌入式应用入门--点灯

本篇实现对gpio的控制,通过控制输出进行gpio的点灯操作。 硬件 我们来操作IO2,控制绿色的灯。 软件 GPIO API API名称 说明 hi_u32 hi_gpio_deinit(hi_void); GPIO模块初始化 hi_u32 hi_io_set_pull(hi_io_name id, hi_io_pull val); 设置某个IO…

如何使用xurlfind3r查找目标域名的已知URL地址

关于xurlfind3r xurlfind3r是一款功能强大的URL地址查询工具,该工具本质上是一个CLI命令行工具,可以帮助广大研究人员从多种在线源来查询目标域名的已知URL地址。 功能介绍 1、从被动在线源获取URL地址以实现最大数量结果获取; 2、支持从Way…

python 地图+经纬度标记

如果你想在地图上显示标注点并在标注点旁边显示文字,可以使用folium.Marker的popup参数来实现。这个参数允许你设置在标注点上点击时显示的文本内容。以下是修改后的示例代码,演示如何在地图上显示带有文字标注的标注点: import folium# 创建…

leetcode打卡#day45 携带研究材料(第七期模拟笔试)、518. 零钱兑换 II、377. 组合总和 Ⅳ、爬楼梯(第八期模拟笔试)

携带研究材料&#xff08;第七期模拟笔试&#xff09; #include<iostream> #include<algorithm> #include<vector>using namespace std;int main() {int N, V;cin >> N >> V;vector<int> weights(N1);vector<int> values(V1);int w…

遗传算法浅理解

1. 什么是遗传算法&#xff1f; ​ 遗传算法&#xff0c;又称为 Genetic algorithm(GA)Genetic algorithm(GA)。其主要思想就是模拟生物的遗传与变异。它的用途非常广泛&#xff0c;可以用于加速某些求最大或者最小值的算法&#xff08;换句话说就是加速算法收敛&#xff0c;最…

实现企业可持续发展目标,ISCC能起什么作用呢?

国际可持续发展和碳认证 (ISCC) 基于气候变化已经成为全球面临的重大挑战之一、可再生能源需求不断增长的这个大背景下&#xff0c;企业的可持续发展诉求正日益显现&#xff0c;尤其当下消费者对于环境和社会责任意识的提升&#xff0c;需要更透明的供应链证明&#xff0c;同时…

移动端专业视频剪辑解决方案,深度编辑,专业级体验

面对众多繁杂的移动端视频编辑软件&#xff0c;如何挑选一款既高效又专业的解决方案&#xff0c;成为众多企业关注的焦点。美摄科技凭借其卓越的技术实力&#xff0c;推出了面向企业的移动端专业视频剪辑解决方案&#xff0c;助力企业轻松打造高质量视频内容。 一、深度编辑&a…

OAuth 2.0:现代应用程序的授权标准

前言 随着互联网和移动应用的发展&#xff0c;应用程序之间的交互变得越来越普遍。用户希望通过单一的身份认证在多个平台上无缝体验&#xff0c;这就要求不同的应用程序能够安全地共享用户数据。而 OAuth 2.0 正是为了解决这一问题而设计的&#xff0c;它提供了一种标准机制&…

6月16日-英语学习日记-(专科生)

我能够走到对岸的&#xff0c;我相信我自己&#xff0c;自己该和过去的事情做一个了断了&#xff01; 符号区别句子&#xff0c;通过感叹符号可以知道那些句子是一个感叹句。 In recent years 最近几年 commander n军官&#xff0c;长官 自己今天对了一道题目&#xff1a; …

Golang 百题(实战快速掌握语法)_1

整形转字符串类型 实验介绍 本实验将展示三种方法来实现整形类型转字符串类型。 知识点 strconvfmt Itoa 函数 代码实例 Go 语言中 strconv 包的 itoa 函数输入一个 int 类型&#xff0c;返回转换后的字符串。下面是一个例子。 package mainimport ("fmt"&qu…

C语言 -- 宏的变长参数定义

C语言宏定义中的可变参数处理 在C语言的宏定义中&#xff0c;我们可以使用可变参数来创建更加灵活和通用的宏。C99标准引入了__VA_ARGS__&#xff0c;而GNU编译器扩展了...args。这两者在处理可变参数时有所不同。本文将介绍它们的区别、使用场景以及相关示例。 背景介绍 __…

wps 二维数据转转一维度数据

HSTACK(TOCOL(C2:H2&A3:A8),TOCOL(B3:B8&C1:H1),TOCOL(C3:H8))

网络编程(三)UDP TFTP协议

文章目录 一、 UDP&#xff08;一&#xff09;概述&#xff08;二&#xff09;流程 二、收发函数&#xff08;一&#xff09;recvfrom&#xff08;二&#xff09;sendto 三、实现一个简单的udp服务端和客户端四、实现tftp客户端协议 一、 UDP &#xff08;一&#xff09;概述 …

Spring-事件

Java 事件/监听器编程模型 设计模式-观察者模式的拓展 可观察者对象(消息发送者) Java.util.Observalbe观察者 java.util.Observer 标准化接口(标记接口) 事件对象 java.util.EventObject事件监听器 java.util.EventListener public class ObserverDemo {public static vo…

React汇率小案例

import React from "react"; import Money from "./components/Money"; class App extends React.Component { // state state { dollar: , money: } transformRmb (value) > { this.setState({ // 保留后两位 并判断valu…

ASPICE标准与ASPICE认证:提升汽车软件开发质量与效率的关键途径

在当今日新月异的科技时代&#xff0c;软件产品的质量和可靠性成为了企业赢得市场的关键。而ASPICE&#xff08;Automotive SPICE&#xff09;标准&#xff0c;作为汽车行业中软件过程评估的国际通用标准&#xff0c;正逐渐引起行业的广泛关注。那么&#xff0c;ASPICE标准究竟…

【Rhino】【Python】Replace specified context of text object批量替换文字对象的指定内容

文章目录 在Rhino中批量修改文字对象内容的Python脚本脚本代码主要功能介绍1. 导入 rhinoscriptsyntax 模块2. 定义批量修改文字对象内容的函数3. 获取所有对象4. 遍历所有对象并修改文字内容5. 输出修改结果6. 设置旧文本和新文本&#xff0c;并运行函数 运行脚本总结 在Rhino…