Java NIO

Java NIO

一,介绍

Java NIO(New IO)是 JDK 1.4 引入的一组新的 I/O API,用于支持非阻塞式 I/O 操作。相比传统的 Java IO API,NIO 提供了更快、更灵活的 I/O 操作方式,可以用于构建高性能网络应用程序。

Java NIO 的主要组成部分包括:

  1. Channel:通道是一个在应用程序和文件、网络套接字之间的连接。可以通过通道来进行数据的读取和写入。
  2. Buffer:缓冲区是一个容器,用于存储数据。在 NIO 中,所有的数据读取和写入都是通过缓冲区进行的。
  3. Selector:选择器用于监听多个 NIO 通道的事件,如读写事件。当某个通道发生事件时,选择器会通知该事件并对其进行处理。

相比传统的 Java IO,Java NIO 的优点包括:

  1. 非阻塞模式:NIO 可以使用非阻塞模式进行网络编程,使程序不必等待网络操作完成才能进行其他操作,提高了程序的响应速度。
  2. 多路复用:一个线程可以同时处理多个 NIO 通道,减少了线程的开销和资源占用。
  3. 缓冲区操作:NIO 使用缓冲区进行数据读取和写入,可以提高数据访问速度。

下面是 Java NIO 常用类和接口:

  1. Channel:提供了各种类型的通道接口,如 FileChannel、DatagramChannel、SocketChannel 和 ServerSocketChannel 等。
  2. Buffer:提供了各种类型的缓冲区实现,如 ByteBuffer、CharBuffer、ShortBuffer 和 DoubleBuffer 等。
  3. Selector:提供了 Selector 接口,用于监听多个通道的事件,可以使用一个线程处理多个通道。

总之,Java NIO 提高了网络编程的效率和性能,使得程序可以处理更多并发请求。但同时需要注意 NIO 的复杂性和学习难度,需要仔细理解其原理和使用规范。

二,区别

Java IO(传统IO)和 Java NIO(New IO)是两种不同的 I/O API,它们在设计和使用上有一些区别。

  1. 工作方式:
    • Java IO 是基于流(Stream)的模型。它通过字节流和字符流来进行数据读写,每次读写一个或多个字节或字符。
    • Java NIO 是基于缓冲区(Buffer)和通道(Channel)的模型。它将数据读取到缓冲区,然后通过通道进行传输,可以实现非阻塞的 I/O 操作。
  1. 阻塞与非阻塞:
    • Java IO 是阻塞式的,读写操作会导致线程阻塞,直到数据可用或操作完成。
    • Java NIO 支持非阻塞式的 I/O 操作。使用选择器(Selector)可以监听多个通道的事件,只处理已准备好的通道,提高了并发性能。
  1. 处理方式:
    • Java IO 使用面向流(Stream-Oriented)的方式,以字节流和字符流为核心,通过流的读写进行数据处理。
    • Java NIO 使用面向缓冲区(Buffer-Oriented)的方式,先将数据读取到缓冲区,然后再从缓冲区中进行读写操作。
  1. API 设计:
    • Java IO 提供了较简单易用的 API,但在处理大量并发连接时可能会遇到性能瓶颈。
    • Java NIO 提供了更灵活、更底层的 API,允许应用程序更好地控制 I/O 操作,提供了更高的性能和并发处理能力。

总体而言,Java IO 更适合处理简单的 I/O 操作,而 Java NIO 则更适合构建高性能的网络及并发应用程序。但是,Java NIO 的编程模型相对复杂,需要更深入的理解和学习。选择使用哪种 API 取决于具体的需求和应用场景。

三,示例代码

下面是使用Java NIO进行文件读写和网络通信的示例代码:

1. 使用Java NIO进行文件读取和写入:

import java.io.*;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;public class NIOFileExample {public static void main(String[] args) {try {RandomAccessFile inputFile = new RandomAccessFile("input.txt", "r");RandomAccessFile outputFile = new RandomAccessFile("output.txt", "rw");FileChannel inputChannel = inputFile.getChannel();FileChannel outputChannel = outputFile.getChannel();ByteBuffer buffer = ByteBuffer.allocate(1024);while (inputChannel.read(buffer) != -1) {// Switch buffer from writing to reading mode and vice versabuffer.flip();outputChannel.write(buffer);buffer.clear(); // Clear buffer for next read}inputChannel.close();outputChannel.close();inputFile.close();outputFile.close();System.out.println("File copied successfully.");} catch (IOException e) {e.printStackTrace();}}
}


 

2. 使用Java NIO进行网络通信:


import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.SocketChannel;public class NIONetworkExample {public static void main(String[] args) {try {SocketChannel socketChannel = SocketChannel.open();socketChannel.connect(new InetSocketAddress("example.com", 80));String request = "GET / HTTP/1.1\r\nHost: example.com\r\n\r\n";ByteBuffer buffer = ByteBuffer.wrap(request.getBytes());socketChannel.write(buffer);ByteBuffer responseBuffer = ByteBuffer.allocate(1024);while (socketChannel.read(responseBuffer) != -1) {responseBuffer.flip();System.out.println(new String(responseBuffer.array()));responseBuffer.clear();}socketChannel.close();System.out.println("Request sent and received successfully.");} catch (IOException e) {e.printStackTrace();}}
}

请注意,在实际应用中,需要正确关闭通道和处理异常。以上代码仅作为示例,实际使用时需要根据实际需求进行适当的优化和异常处理。

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

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

相关文章

系统设计 - 我们如何通俗的理解那些技术的运行原理 - 第八部分:Linux、安全

本心、输入输出、结果 文章目录 系统设计 - 我们如何通俗的理解那些技术的运行原理 - 第八部分:Linux、安全前言Linux 文件系统解释应该知道的 18 个最常用的 Linux 命令HTTPS如何工作?数据是如何加密和解密的?为什么HTTPS在数据传输过程中会…

领导:给你一个项目,如何开展性能测试工作。我:***

01 怎么开展性能测试 01 测试的一般步骤 性能测试的工作是基于系统功能已经完备或者已经趋于完备之上的,在功能还不够完备的情况下没有多大的意义(后期功能完善上会对系统的性能有影响,过早进入性能测试会出现测试结果不准确、浪费测试资源…

ESRI ArcGIS Desktop 10.8.2图文安装教程及下载

ArcGIS 是由美国著名的地理信息系统公司 Esri 开发的一款地理信息系统软件,它是目前全球最流行的 GIS 软件之一。ArcGIS 提供了图形化用户界面和数据分析工具,可以帮助用户管理、分析和可视化各种空间数据。ArcGIS Desktop是一个完整的桌面GIS软件套件&a…

20231024后端研发面经整理

1.如何在单链表O(1)删除节点? 狸猫换太子 2.redis中的key如何找到对应的内存位置? 哈希碰撞的话用链表存 3.线性探测哈希法的插入,查找和删除 插入:一个个挨着后面找,知道有空位 查找:一个个挨着后面找…

Ai写作创作系统ChatGPT网站源码+图文搭建教程+支持GPT4.0+支持ai绘画(Midjourney)/支持OpenAI GPT全模型+国内AI全模型

一、AI创作系统 SparkAi创作系统是基于OpenAI很火的ChatGPT进行开发的Ai智能问答系统AI绘画系统,支持OpenAI GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署…

记一次渗透测试事件

一、漏洞发现 拿到登录的接口,丢到sqlmap里面跑一把,发现延时注入 进一步查询,发现是sa权限,直接os-shell whomai查询发现是管理员权限 os-shell执行命令太慢了,直接进行nc 反弹 执行base64 加密后的powershell命令&…

DALL·E 3怎么用?DALL·E 3如何申请开通 ?DALL·E 3如何免费使用?AI绘画教程来喽~

一、引言 DALLE 3 是 OpenAI 在上个月(2023 年 9 月)发布的一个文生图模型。 相对于 Midjourney 以及 Stable Diffusion,DALLE 3 最大的便利之处在于,用户不需要掌握 Prompt 的写法了,直接自然语言描述即可。 甚至还…

【文件操作】Java -操作File对象

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 文件操作 Java - File对象 Java - File对象 Fi…

ssm+vue的汽车站车辆运营管理系统(有报告)。Javaee项目,ssm vue前后端分离项目。

演示视频: ssmvue的汽车站车辆运营管理系统(有报告)。Javaee项目,ssm vue前后端分离项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系…

面对史上最难求职季,哪些测试技能更容易拿到offer?

在一线大厂,没有测试这个岗位,只有测开这个岗位。这几年,各互联网大厂技术高速更新迭代,软件测试行业也正处于转型期。传统的功能测试技术逐步淘汰,各种新的测试技术层出不穷,测试人员的薪资也水涨船高。与…

数据库连接池有什么用?它有哪些关键参数?

首先,数据库连接池是一种池化技术,池化技术的核心思想是实现资源的复用,避免资源重复创建销毁的开销。而在数据库的应用场景里面,应用程序每次向数据库发起 CRUD 操作的时候,都需要创建连接.在数据库访问量较大的情况下…

28、Flink 的SQL之DROP 、ALTER 、INSERT 、ANALYZE 语句

Flink 系列文章 1、Flink 部署、概念介绍、source、transformation、sink使用示例、四大基石介绍和示例等系列综合文章链接 13、Flink 的table api与sql的基本概念、通用api介绍及入门示例 14、Flink 的table api与sql之数据类型: 内置数据类型以及它们的属性 15、Flink 的ta…

Linux PAGE_ALIGN 宏定义的理解

前言 最近再阅读 Linux ion(一种内存分配管理)时,遇到了 PAGE_ALIGN 宏,这个宏到底是怎么工作的? 【页对齐】时什么意思? 页大小就是 4096 吗? 追踪 PAGE_ALIGN 通过一步一步的追踪&#xff0…

Stream流式处理

Stream流式处理: 建立在Lambda表达式基础上的多数据处理技术。 可以对集合进行迭代、去重、筛选、排序、聚合等处理,极大的简化了代码量。 Stream常用方法 Stream流对象的五种创建方式 //基于数组 String[] arr {"a","b","c…

ubuntu 中使用Qt连接MMSQl,报错libqsqlodbc.so: undefined symbol: SQLAllocHandle

Qt4.8.7的源码编译出来的libqsqlodbc.so,在使用时报错libqsqlodbc.so: undefined symbol: SQLAllocHandle,需要在编译libqsqlodbc.so 的项目pro文件加上LIBS -L/usr/local/lib -lodbc。 这里的路径根据自己的实际情况填写。 编辑: 使用uni…

Auth.js:多合一身份验证解决方案 | 开源日报 No.60

nodejs/node Stars: 96.2k License: NOASSERTION Node.js 是一个开源的、跨平台的 JavaScript 运行时环境。它具有以下关键特性和核心优势: 强大:Node.js 提供了强大且高效的服务器端运行能力,可以处理并发请求,并支持异步编程…

Adobe Photoshop 基本操作

PS快捷键 图层 选择图层 Ctrl T:可以对图层的大小和位置进行调整 填充图层 MAC: AltBackspace (前景) or CtrlBackspace (背景) WINDOWS: AltDelete (前景) or CtrlDelete (背景) 快速将图层填充为前景色或背景色 平面化图层(盖印图层&#xff09…

kubernates 集群实战-安装K3s集群

安装K3s集群 安装K3s集群环境准备安装 docker主节点安装work 节点验证环境 安装K3s集群 K3S是一种轻量级的Kubernetes发行版,安装和运行只需要一个二进制文件。相比之下,K8S需要更多的步骤和资源来安装和部署,例如设置etcd集群、安装控制平面…

C# winform如何实现数据的保存和读取

在c#winform中我们在写程序时,经常需要进行数据处理,那么数据如何保存和读取(下面我们通过序列化和反序列化的方式来实现) 第一步: 我们建立一个winform窗体 第二步: 构建一个外部实体类(Student类) 第…

计算机视觉-数学基础*变换域表示

被研究最多的图像(或任何序列数据)变换域表示是通过傅 里叶分析 。所谓的傅里叶表示就是使用 正弦函数的线性组合来表示信号。对于一个给定的图像I(n1,n2) ,可以用如下方式分解它(即逆傅里叶变换): 其中&a…