当前位置: 首页 > wzjs >正文

企业网站建设 电脑配置青岛网红打卡景点

企业网站建设 电脑配置,青岛网红打卡景点,wordpress hexo主题制作,中国企业网财经📌 引言 在前面的文章中,我们介绍了序列化和反序列化(Java进阶篇之序列化和反序列化)在 Java 的 I/O 体系中,java.io提供了传统的BIO(Blocking I/O,阻塞 I/O),它适用于小…

📌 引言

在前面的文章中,我们介绍了序列化和反序列化(Java进阶篇之序列化和反序列化)在 Java 的 I/O 体系中,java.io提供了传统的BIO(Blocking I/O,阻塞 I/O),它适用于小规模的数据交互。但在高并发、大数据量传输的场景下,java.nio(New I/O,非阻塞 I/O)提供了更高效的解决方案。NIO 采用**缓冲区(Buffer)+ 通道(Channel)**的方式,提高了数据处理能力,并支持 多路复用(Selector),大大提升了 I/O 性能。

本篇文章将详细介绍 Java NIO 的基础概念、核心组件、使用示例,并对比传统 IO,帮助你更好地理解 NIO 的工作原理。


目录

📌 引言

🏗 一、NIO 概述

1️⃣ 传统 I/O(BIO)的缺点

2️⃣ NIO 的优势

🛠 二、NIO 的核心组件

1️⃣ Buffer(缓冲区)

2️⃣ Channel(通道)

3️⃣ Selector(多路复用器)

🔄 四、NIO vs 传统IO

🎯 结语


🏗 一、NIO 概述

1️⃣ 传统 I/O(BIO)的缺点

  • 阻塞模式:BIO 采用 流式处理,读取或写入数据时必须等待操作完成,线程可能被阻塞。
  • 线程消耗大:每个连接通常对应一个独立的线程,在高并发场景下,线程资源消耗过多,导致性能下降。
  • 数据复制:BIO 需要频繁在用户空间和内核空间之间拷贝数据,影响 I/O 性能。

2️⃣ NIO 的优势

  • 非阻塞 I/O:NIO 允许一个线程管理多个连接,无需为每个连接创建线程。
  • 基于 Buffer(缓冲区):相比于传统的 Stream(流),NIO 以块(Block)形式处理数据,减少数据拷贝,提高吞吐量。
  • 使用 Channel(通道):双向数据通道,可同时进行读写操作,避免了 BIO 的单向流式传输。
  • 支持 Selector(多路复用器):一个线程可以管理多个通道,提高资源利用率。

🛠 二、NIO 的核心组件

Java NIO 主要由 Buffer(缓冲区)、Channel(通道)、Selector(选择器) 组成:

1️⃣ Buffer(缓冲区)

缓冲区用于存储数据,NIO 不再直接与流交互,而是通过 Buffer 进行数据的读取和写入。常见的 Buffer 类型:

Buffer 类型作用
ByteBuffer处理字节数据
CharBuffer处理字符数据
IntBuffer处理整数数据
FloatBuffer处理浮点数数据
LongBuffer处理长整数数据
DoubleBuffer处理双精度浮点数数据

Buffer 关键方法:

  • allocate(int capacity):创建指定容量的 Buffer。
  • put(data):向 Buffer 写入数据。
  • flip():切换为读模式。
  • get():从 Buffer 读取数据。
  • clear():清空 Buffer,准备下一次写入。

示例:使用 ByteBuffer 存储数据

import java.nio.ByteBuffer;public class BufferExample {public static void main(String[] args) {ByteBuffer buffer = ByteBuffer.allocate(10); // 创建容量为 10 的缓冲区// 写入数据buffer.put((byte) 1);buffer.put((byte) 2);buffer.put((byte) 3);buffer.flip(); // 切换到读模式while (buffer.hasRemaining()) {System.out.println(buffer.get()); // 读取数据}}
}

2️⃣ Channel(通道)

通道类似于传统的流(Stream),但它支持双向数据传输(既可读,也可写)。

常见的 Channel 实现:

  • FileChannel:用于文件读写。
  • SocketChannel:用于网络通信(类似 Socket)。
  • ServerSocketChannel:用于服务器端的 Socket 监听。
  • DatagramChannel:用于 UDP 连接。

示例:使用 FileChannel 读取文件

import java.io.FileInputStream;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;public class FileChannelExample {public static void main(String[] args) throws Exception {FileInputStream fis = new FileInputStream("test.txt");FileChannel channel = fis.getChannel();ByteBuffer buffer = ByteBuffer.allocate(1024);channel.read(buffer);buffer.flip(); // 切换到读模式while (buffer.hasRemaining()) {System.out.print((char) buffer.get());}channel.close();fis.close();}
}

3️⃣ Selector(多路复用器)

Selector 允许 单个线程管理多个通道,提高了 I/O 处理效率,特别适用于高并发场景,如 Web 服务器、聊天室等。

Selector 关键方法

  • select():阻塞直到至少一个通道准备就绪。
  • selectNow():非阻塞检查就绪通道。
  • register():将 Channel 注册到 Selector 上。

示例:使用 Selector 监听多个 Channel

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.*;
import java.net.InetSocketAddress;
import java.util.Iterator;public class SelectorExample {public static void main(String[] args) throws IOException {Selector selector = Selector.open();ServerSocketChannel serverChannel = ServerSocketChannel.open();serverChannel.bind(new InetSocketAddress(8080));serverChannel.configureBlocking(false);serverChannel.register(selector, SelectionKey.OP_ACCEPT);while (true) {selector.select(); // 阻塞等待事件Iterator<SelectionKey> iterator = selector.selectedKeys().iterator();while (iterator.hasNext()) {SelectionKey key = iterator.next();iterator.remove();if (key.isAcceptable()) { // 处理新连接SocketChannel client = serverChannel.accept();client.configureBlocking(false);client.register(selector, SelectionKey.OP_READ);System.out.println("Client connected: " + client.getRemoteAddress());} else if (key.isReadable()) { // 读取数据SocketChannel client = (SocketChannel) key.channel();ByteBuffer buffer = ByteBuffer.allocate(1024);int bytesRead = client.read(buffer);if (bytesRead > 0) {buffer.flip();System.out.println("Received: " + new String(buffer.array(), 0, bytesRead));}}}}}
}

🔄 四、NIO vs 传统IO

对比项传统 I/O (BIO)NIO (非阻塞 I/O)
数据处理基于流基于缓冲区(Buffer)
阻塞模式阻塞(每次读写都等待完成)非阻塞(一个线程可管理多个连接)
适用场景小数据量、单连接高并发、大量连接
线程模型每连接一个线程单线程管理多个连接

🎯 结语

Java NIO 是高性能 I/O 编程的基础,适用于高并发、低延迟的应用场景。本文介绍了 NIO 的基本概念、核心组件(Buffer、Channel、Selector)及代码示例,希望能帮助你更好地理解 NIO 的应用。

下一步,你可以尝试使用NIO实现简单的 Web 服务器或聊天室,进一步加深对非阻塞 I/O 的理解!💡

在接下来的文章中,我们将继续探讨Java中的多线程以及其他重要特性,敬请期待!

👉 如果你觉得这篇文章对你有所帮助,欢迎点赞、收藏、分享!😊


文章转载自:

http://0kbQ35s6.nmkbL.cn
http://VQPTrw4r.nmkbL.cn
http://1kvSotsc.nmkbL.cn
http://ExovVe5D.nmkbL.cn
http://NPWTBoMl.nmkbL.cn
http://QNnTqFgW.nmkbL.cn
http://IZ5hPenZ.nmkbL.cn
http://0CjzWh4I.nmkbL.cn
http://WLiWzWDv.nmkbL.cn
http://ZqEVUkMl.nmkbL.cn
http://yjMjp5Gd.nmkbL.cn
http://XM5XM2Uv.nmkbL.cn
http://1YzTuDvd.nmkbL.cn
http://hB1nX9H5.nmkbL.cn
http://29Qaa7BU.nmkbL.cn
http://Llfg7Q22.nmkbL.cn
http://qMnUwVyj.nmkbL.cn
http://9ogdiYNl.nmkbL.cn
http://DQ4TJGI0.nmkbL.cn
http://emTyg57S.nmkbL.cn
http://px26lFS3.nmkbL.cn
http://sXCQZD1I.nmkbL.cn
http://OPuQDtJY.nmkbL.cn
http://eCpyOa2m.nmkbL.cn
http://BIYlCQH9.nmkbL.cn
http://KIm0EzSy.nmkbL.cn
http://ZeyG6zKO.nmkbL.cn
http://1q0miJsL.nmkbL.cn
http://AvjRMvAU.nmkbL.cn
http://SabZSAlP.nmkbL.cn
http://www.dtcms.com/wzjs/705902.html

相关文章:

  • 海关网站建设方案用邮箱找回智慧团建密码
  • 百度网站建设北京郑州网站建设口碑好
  • 让你做一个旅游网站你会怎么做如何做跨境电商怎么做
  • 济源网站维护番禺做网站的
  • 平台网站怎么做的备案的域名拿来做别的网站
  • 网站怎么做筛选河南网站优化外包服务
  • 怀化市建设局门户网站个人在百度上发广告怎么发
  • 多合一建网站网站做浮动边框asp代码
  • 体育健身网站建设上海网站建设caiyiduo
  • 网站制作优化网站运营设计
  • 兴业大街网站建设自有品牌如何推广
  • 订单网站模块小程序搭建需要多久
  • 西安网站建设 中讯创赢网站设计开发工程师
  • 网站后台更新前台更新不东莞seo优化
  • 网站设计用ps 怎么做深圳建设网站
  • 常见的电子商务网站有哪些天津网站建设制作
  • 爱站网关键词密度关键词优化是什么
  • 网站建设前wordpress中文教程 下载
  • 手机优化网站建设php彩票网站建设教程
  • 贾汪徐州网站开发wordpress太难用了
  • 小米商城网站建设中国500强排行榜
  • 济宁有做企业网站吗济南网页制作设计营销
  • 企业网站建设教程北京住房和城乡建设网官网
  • 杭州网站建设响应式周易八字排盘系统网站建设
  • 成都没有做网站的公司给个免费的网站好人有好报
  • 北京建设监理网站wordpress手机登录跳转页面模板
  • 广东建设报网站电子商务自助建网站
  • 电商网站建设策划天猫网站怎么做
  • 网站建设 中企动力南通建网站平台要多少钱
  • 快速搭建网站框架的工具多媒体设计与制作毕业设计