IO模式精讲总结

一、IO模型概述

Java中的IO模型主要分为BIO(同步阻塞IO)、NIO(同步非阻塞IO)和AIO(异步非阻塞IO)三种。它们分别适用于不同的业务场景,理解其核心机制对高性能网络编程至关重要。


二、BIO:同步阻塞IO

1. 核心机制

BIO基于“一连接一线程”模型,服务端通过ServerSocket监听端口,客户端通过Socket发起连接。当服务端调用accept()read()时,线程会阻塞直至数据就绪。

2. 代码示例

服务端代码片段

ServerSocket serverSocket = new ServerSocket(9999);
Socket socket = serverSocket.accept(); // 阻塞
InputStream is = socket.getInputStream();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
String msg = br.readLine(); // 阻塞直至数据到达

客户端代码片段

Socket socket = new Socket("127.0.0.1", 9999);
PrintStream ps = new PrintStream(socket.getOutputStream());
ps.println("Hello BIO!");
ps.flush();

3. 优缺点分析

  • 优点:编程简单,适合低并发场景。
  • 缺点:线程资源消耗大,高并发时易导致线程栈溢出。

三、NIO:同步非阻塞IO

1. 核心组件

NIO的三大核心为通道(Channel)缓冲区(Buffer)选择器(Selector)

  • Channel:双向通信管道,替代BIO的单向流。
  • Buffer:数据存储容器,支持高效读写。
  • Selector:多路复用器,单线程管理多个Channel的事件。

2. 工作机制

通过Selector.select()监听事件,实现非阻塞IO。服务端仅需一个线程即可处理多个连接请求,显著提升性能。

服务端代码片段

ServerSocketChannel serverChannel = ServerSocketChannel.open();
serverChannel.configureBlocking(false);
serverChannel.bind(new InetSocketAddress(9090));
Selector selector = Selector.open();
serverChannel.register(selector, SelectionKey.OP_ACCEPT);while (true) {selector.select(); // 事件监听Set<SelectionKey> keys = selector.selectedKeys();Iterator<SelectionKey> iter = keys.iterator();while (iter.hasNext()) {SelectionKey key = iter.next();if (key.isAcceptable()) {// 处理连接事件} else if (key.isReadable()) {// 处理读事件}iter.remove();}
}

3. Buffer操作流程

  1. 写入数据buffer.put(data)
  2. 切换为读模式buffer.flip()
  3. 读取数据buffer.get()
  4. 清空缓冲区buffer.clear()

示例

ByteBuffer buffer = ByteBuffer.allocate(1024);
buffer.put("Hello NIO".getBytes());
buffer.flip();
while (buffer.hasRemaining()) {System.out.print((char) buffer.get());
}

4. 适用场景

适用于高并发短连接场景(如聊天服务器)。


四、AIO:异步非阻塞IO

1. 核心机制

AIO基于操作系统级别的异步通知机制,IO操作由OS完成后回调通知应用,无需线程阻塞。核心类包括AsynchronousServerSocketChannelCompletionHandler

2. 代码示例

AsynchronousServerSocketChannel server = AsynchronousServerSocketChannel.open();
server.bind(new InetSocketAddress(9090));
server.accept(null, new CompletionHandler<AsynchronousSocketChannel, Void>() {@Overridepublic void completed(AsynchronousSocketChannel client, Void attachment) {ByteBuffer buffer = ByteBuffer.allocate(1024);client.read(buffer, buffer, new CompletionHandler<Integer, ByteBuffer>() {@Overridepublic void completed(Integer result, ByteBuffer buf) {System.out.println("收到数据:" + new String(buf.array()));}});}
});

3. 适用场景

适合长连接、重操作场景(如文件服务器),但实际应用中因编程复杂度和兼容性问题,使用较少。


五、三种IO模型对比

特性BIONIOAIO
阻塞性同步阻塞同步非阻塞异步非阻塞
线程模型一连接一线程单线程多路复用回调通知机制
适用场景低并发、简单业务高并发短连接(如IM系统)高并发长连接(如文件传输)
编程复杂度简单复杂复杂
JDK支持JDK1.0JDK1.4JDK1.7

六、总结

  1. BIO:适合快速原型开发,但需避免用于高并发场景。
  2. NIO:Netty等框架的底层实现,推荐用于高性能服务器开发。
  3. AIO:在特定场景下性能优异,但需评估框架支持度。

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

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

相关文章

使用pybind11开发c++扩展模块输出到控制台的中文信息显示乱码的问题

使用pybind11开发供Python项目使用的C++扩展模块时,如果在扩展模块的C++代码中向控制台输出的信息中包含中文,python程序的控制台很容易出现乱码。以如下C++扩展框架代码为例(这是对上一篇文章简明使用pybind11开发pythonc+扩展模块教程-CSDN博客中的C++扩展框架代码进行少量…

通过jstack分析线程死锁场景

死锁的四个必要条件&#xff1a;互斥、持有并等待、不可抢占、循环等待。 死锁场景是两个线程各自持有某个锁&#xff0c;并试图获取对方持有的锁&#xff0c;导致互相等待。 创建死锁示例代码 package io.renren.controller;import org.springframework.web.bind.annotation…

PyTorch梯度:深度学习的引擎与实战解析

一、梯度&#xff1a;深度学习中的指南针 1.1 什么是梯度&#xff1f; 梯度是函数在某一点变化率最大的方向及其大小&#xff0c;就像爬山时最陡峭的上坡方向。在深度学习中&#xff0c;梯度告诉我们如何调整神经网络参数&#xff0c;使损失函数最小化。 1.2 梯度的重要性 …

【Python爬虫】详细入门指南

目录 一、简单介绍 二、详细工作流程以及组成部分 三、 简单案例实现 一、简单介绍 在当今数字化信息飞速发展的时代&#xff0c;数据的获取与分析变得愈发重要&#xff0c;而网络爬虫技术作为一种能够从互联网海量信息中自动抓取所需数据的有效手段&#xff0c;正逐渐走入…

Golang|Channel 相关用法理解

文章目录 用 channel 作为并发小容器channel 的遍历channel 导致的死锁问题用 channel 传递信号用 channel 并行处理文件用channel 限制接口的并发请求量用 channel 限制协程的总数量 用 channel 作为并发小容器 注意这里的 ok 如果为 false&#xff0c;表示此时不仅channel为空…

Windows单机模拟MySQL主从复制

这里写自定义目录标题 下载MySQL ZIP压缩包安装主库1、创建配置文件2、安装服务3、初始化数据库4、启动服务5、配置主库 安装从库1、配置ini文件2、安装服务3、初始化数据库4、启动服务5、配置从库6、验证从库状态 操作主库验证 下载MySQL ZIP压缩包 https://dev.mysql.com/do…

OSPF路由引入

一、基本概念与作用 1.OSPF路由引入指通过自治系统边界路由器&#xff08;ASBR&#xff09;将外部路由&#xff08;如BGP、RIP、静态路由或其他OSPF进程的路由&#xff09;注入当前OSPF域&#xff0c;实现跨协议或跨区域的网络互通‌。 其核心作用包括&#xff1a; ‌扩展网…

弱口令爆破

1.简单介绍 弱口令是指一些简单易猜的密码&#xff0c;可通过社工方式和一些爆破工具进行破解&#xff0c;以下介绍一款爆破工具的用法。burpsuite简称BP&#xff0c;一款可以利用字典破解账户密码的工具。 2.部署网站 可以使用PHPstudy的Apache服务&#xff0c;也可以使用I…

Vue3+Vite前端项目部署后部分图片资源无法获取、动态路径图片资源报404错误的原因及解决方案

目录 Vue3vite前端项目部署后部分图片资源无法获取、动态路径图片资源报404错误的原因及解决方案 一、情景介绍 1、问题出现的场景 2、无法加载的图片写法 二、反向代理原理简介 三、造成该现象的原因 四、解决方案 1、放弃动态渲染 2、在页面挂载的时候引入图片资源 …

详解如何从零用 Python复现类似 GPT-4o 的多模态模型

&#x1f9e0; 向所有学习者致敬&#xff01; “学习不是装满一桶水&#xff0c;而是点燃一把火。” —— 叶芝 我的博客主页&#xff1a; https://lizheng.blog.csdn.net &#x1f310; 欢迎点击加入AI人工智能社区&#xff01; &#x1f680; 让我们一起努力&#xff0c;共创…

榕壹云无人共享系统:基于SpringBoot+MySQL+UniApp的物联网共享解决方案

无人共享经济下的技术革新 随着无人值守经济模式的快速发展&#xff0c;传统共享设备面临管理成本高、效率低下等问题。榕壹云无人共享系统依托SpringBootMySQLUniApp技术栈&#xff0c;结合物联网与移动互联网技术&#xff0c;为商家提供低成本、高可用的无人化运营解决方案。…

基于PHP的酒店网上订房系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 酒店服务是旅游行业的一个重要组成部分&#xff0c;它的作用已经从过去的单一的住宿、结算帐务向全面、高水平的服务型酒店转变。酒店的服务工作贯穿于整个酒店的市场营销、预定、入住、退房、结账等环节&#xff0c;酒店要提高整体工作水平&#xff0c;简化工作程序&…

【Linux生成SSH秘钥实现远程连接】Linux生成SSH秘钥对与修改服务配置文件实现无密码远程连接

文章目录 前言1. Linux 生成SSH秘钥对2. 修改SSH服务配置文件3. 客户端秘钥文件设置4. 本地SSH私钥连接测试5. Linux安装Cpolar工具6. 配置SSHTCP公网地址7. 远程SSH私钥连接测试8. 固定SSH公网地址9. 固定SSH地址测试 前言 在数字化江湖中&#xff0c;企业对各种技术的需求就…

# linux 设置宽容模式

linux 设置宽容模式 在Linux系统中&#xff0c;通常没有直接称为“宽容模式”的设置选项&#xff0c;但你可以通过几种方式来模拟或调整系统行为&#xff0c;使其表现得更加“宽容”&#xff0c;特别是在处理错误、权限问题或其他潜在问题时。以下是一些常见的方法&#xff1a…

【C++】——lambda表达式

&#x1f31f; 前言:​​C Lambda表达式,当函数开始"叛逆期"​​ 你是否有过这样的崩溃瞬间&#xff1f; 为了写个​​只用到一次​​的排序规则&#xff0c;被迫定义了一个类在std::for_each里塞函数指针&#xff0c;代码瞬间变成"古董级"写法看着层的循环…

深入解析B站androidApp接口:从bilibili.api.ticket.v1.Ticket/GetTicket到SendMsg的技术分析

前言 最近一段时间&#xff0c;我对B站的App接口进行了深入分析&#xff0c;特别是关注了认证机制和私信功能的实现。通过逆向工程和网络抓包&#xff0c;发现了B站移动端API的底层工作原理&#xff0c;包括设备标识生成机制、认证流程和消息传输协议。本文将分享这些研究成果…

从零开始学A2A一:A2A 协议概述与核心概念

A2A 协议概述与核心概念 学习目标 基础理解 掌握A2A协议的基本概念和背景理解协议的设计原则和核心思想了解协议在AI领域的重要性 技术掌握 熟悉A2A协议的核心功能组件掌握能力发现和任务管理机制理解多模态交互和安全通信原则 实践应用 能够设计基于A2A的智能体系统掌握协议…

2025.04.10-拼多多春招笔试第三题

📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 03. 数字重排最大化问题 问题描述 LYA是一位专业的数字设计师。她手中有两个数字序列 s 1 s_1

苍穹外卖day04

Spring Task实现定时处理订单状态 作用&#xff1a;不需要输入提示信号&#xff0c;便可定时自动执行程序 使用步骤 1、启动类上加上注解&#xff08;EnableScheduling&#xff09;开启定时任务调度 2、专门创建一个包来管理执行定时任务的类&#xff0c;该类需要交给IOC容…

BFD:网络链路检测与联动配置全攻略

目录 BFD简介 BFD会话建立方式和检测机制 BFD会话建立过程 BFD工作流程 联动功能 BFD与OSPF联动配置需求 BFD与OSPF联动配置实现 BFD与VRRP联动配置需求 BFD与VRRP联动配置实现 单臂回声 BFD默认参数及调整方法 BFD简介 一种全网统一、检测迅速、监控网络中链…