Java NIO 全面详解:掌握 `Path` 和 `Files` 的一切
在 Java 7 中引入的 NIO (New I/O) 为文件系统和流的操作带来了强大的能力,其中 Path
和 Files
是核心部分。Path
作为对文件路径的抽象,提供了灵活的方式处理文件系统中的路径;Files
则通过一系列静态方法,使得文件的读写、复制、删除等操作变得简单高效。本篇博客将带你深入理解并掌握 Java NIO 中的 Path
和 Files
。
目录
- 什么是 NIO
Path
类详解Path
的创建- 常用方法
- 处理相对路径与绝对路径
- 路径规范化与解析
Files
类详解- 文件和目录操作
- 文件的读写
- 文件的复制与移动
- 文件属性管理
- 异常处理与文件锁定
- 多线程文件操作
- 实战:文件操作中的最佳实践
- 总结
1. 什么是 NIO
Java NIO (New Input/Output) 是 Java 7 中引入的一组新的 IO API。NIO 与传统的 IO API (如 File
) 相比,有几个显著优势:
- 非阻塞 IO: 支持高效的文件系统与网络 IO 操作。
- 更灵活的文件操作:
Path
和Files
提供了一套更强大的文件系统操作接口。 - 通道与缓冲区: 提供了新的数据传输模型,提升了数据处理效率。
Path
和 Files
是 NIO API 中的重要组成部分,用于处理文件和目录。
2. Path
类详解
Path
类是 Java NIO 中用来表示文件路径的核心类,它替代了传统的 File
类。Path
可以表示绝对路径或相对路径,支持平台无关的文件路径操作。
2.1 Path
的创建
创建 Path
对象非常简单,可以使用 Paths.get()
方法:
import java.nio.file.Path;
import java.nio.file.Paths;public class PathExample {public static void main(String[] args) {Path path = Paths.get("/users/documents/file.txt");System.out.println("Path: " + path);}
}
你还可以使用相对路径:
Path relativePath = Paths.get("docs/file.txt");
2.2 常用方法
getFileName()
: 获取文件名。getParent()
: 获取父路径。getRoot()
: 获取根目录。isAbsolute()
: 判断是否是绝对路径。toAbsolutePath()
: 将相对路径转换为绝对路径。
示例:
Path path = Paths.get("/users/documents/file.txt");
System.out.println("文件名: " + path.getFileName()); // 输出: file.txt
System.out.println("父路径: " + path.getParent()); // 输出: /users/documents
System.out.println("根目录: " + path.getRoot()); // 输出: /
2.3 处理相对路径与绝对路径
Path
可以处理相对路径与绝对路径。在相对路径转换为绝对路径时,可以通过 toAbsolutePath()
方法实现:
Path relativePath = Paths.get("file.txt");
Path absolutePath = relativePath.toAbsolutePath();
System.out.println("绝对路径: " + absolutePath);
2.4 路径规范化与解析
有时路径中可能包含冗余的 .
或 ..
,可以使用 normalize()
方法规范化路径:
Path path = Paths.get("/users/../documents/./file.txt");
Path normalizedPath = path.normalize();
System.out.println("规范化路径: " + normalizedPath); // 输出: /documents/file.txt
3. Files
类详解
Files
类提供了操作文件和目录的一系列静态方法。无论是创建、删除、读取还是移动文件,Files
都为这些操作提供了简洁的接口。
3.1 文件和目录操作
createFile()
: 创建新文件。如果文件已存在,会抛出FileAlreadyExistsException
。createDirectory()
: 创建新目录。delete()
: 删除文件或目录。exists()
: 检查文件或目录是否存在。isDirectory()
: 判断路径是否为目录。
Path path = Paths.get("newFile.txt");
if (!Files.exists(path)) {Files.createFile(path);System.out.println("文件已创建: " + path);
} else {System.out.println("文件已存在: " + path);
}Files.delete(path); // 删除文件
3.2 文件的读写
write()
: 将字节数组写入文件。readAllBytes()
: 读取文件中的所有字节。readAllLines()
: 逐行读取文件内容。
示例:
Path filePath = Paths.get("testFile.txt");// 写入文件
Files.write(filePath, "Hello, World!".getBytes());// 读取文件
String content = new String(Files.readAllBytes(filePath));
System.out.println("文件内容: " + content);
3.3 文件的复制与移动
copy()
: 复制文件。move()
: 移动或重命名文件。
Path source = Paths.get("source.txt");
Path target = Paths.get("target.txt");// 复制文件
Files.copy(source, target);// 移动文件
Files.move(source, target);
3.4 文件属性管理
size()
: 获取文件大小。getLastModifiedTime()
: 获取文件的最后修改时间。setLastModifiedTime()
: 设置文件的最后修改时间。
Path filePath = Paths.get("testFile.txt");// 获取文件大小
long size = Files.size(filePath);
System.out.println("文件大小: " + size + " 字节");// 获取最后修改时间
FileTime lastModifiedTime = Files.getLastModifiedTime(filePath);
System.out.println("最后修改时间: " + lastModifiedTime);
4. 异常处理与文件锁定
在处理文件时,异常处理至关重要。例如,当文件不存在时,NoSuchFileException
将会抛出。
try {Path path = Paths.get("nonexistentFile.txt");Files.delete(path);
} catch (NoSuchFileException e) {System.out.println("文件不存在: " + e.getMessage());
}
文件锁定 是一个高级操作,常用于多线程或并发文件操作。通过 FileChannel
可以获取文件的锁:
try (FileChannel channel = FileChannel.open(Paths.get("file.txt"), StandardOpenOption.WRITE)) {FileLock lock = channel.lock();System.out.println("文件已加锁");// 执行写操作lock.release();System.out.println("文件解锁");
}
5. 多线程文件操作
在多线程环境中进行文件操作时,应确保每个线程对文件的访问是安全的。Java 提供了锁定机制来防止多个线程同时写入同一个文件,避免出现数据竞争问题。
此外,可以结合线程池对文件进行并发读取:
ExecutorService executor = Executors.newFixedThreadPool(4);
for (Path file : Files.newDirectoryStream(Paths.get("/mydir"))) {executor.submit(() -> {try {String content = new String(Files.readAllBytes(file));System.out.println("文件内容: " + content);} catch (IOException e) {e.printStackTrace();}});
}
executor.shutdown();
6. 实战:文件操作中的最佳实践
-
资源关闭: 始终确保在文件操作完成后关闭资源。可以使用
try-with-resources
确保资源自动关闭。 -
异常处理: 始终处理可能抛出的异常,特别是在操作外部文件时。
-
并发访问: 使用文件锁或线程安全的机制来确保并发文件访问的安全性。
-
目录遍历的优化: 使用
Files.walkFileTree()
提供更灵活的遍历规则,特别是在处理大量文件时。
7. 总结
本文详细介绍了 Java NIO 中的 Path
和 Files
,包括它们的创建、操作方法、文件属性管理以及高级操作如异常处理、多线程文件操作等。通过这些工具,Java 开发者可以更高效地管理文件系统,处理复杂的文件操作场景。
无论是在简单的文件读取和写入,还是在多线程环境中的并发文件操作中,Path
和 Files
提供了一个现代化、平台无关的接口,极大简化了开发中的文件处理流程。通过良好的异常处理和资源管理,你可以编写出健壮且性能优异的代码。
希望通过这篇文章,你能全面掌握 Path
和 Files
,并在实际开发中灵活运用这些知识。继续深入研究 Java NIO 的其他部分,例如 Channels
和 AsynchronousFileChannel
,可以让你对 Java 文件系统操作有更深入的理解。
如果你有任何问题,欢迎在评论区交流,我们可以一起探讨更多实战中的应用技巧!
相关文章:
Java NIO 全面详解:掌握 `Path` 和 `Files` 的一切
在 Java 7 中引入的 NIO (New I/O) 为文件系统和流的操作带来了强大的能力,其中 Path 和 Files 是核心部分。Path 作为对文件路径的抽象,提供了灵活的方式处理文件系统中的路径;Files 则通过一系列静态方法,使得文件的读写、复制、…...
bluez免提协议hands-free介绍,全到无法想象,bluez hfp ag介绍
零. 前言 由于Bluez的介绍文档有限,以及对Linux 系统/驱动概念、D-Bus 通信和蓝牙协议都有要求,加上网络上其实没有一个完整的介绍Bluez系列的文档,所以不管是蓝牙初学者还是蓝牙从业人员,都有不小的难度,学习曲线也相对较陡,所以我有了这个想法,专门对Bluez做一个系统…...

关于区块链的安全和隐私
背景 区块链技术在近年来发展迅速,被认为是安全计算的突破,但其安全和隐私问题在不同应用中的部署仍处于争论焦点。 目的 对区块链的安全和隐私进行全面综述,帮助读者深入了解区块链的相关概念、属性、技术和系统。 结构 首先介绍区块链…...

特征工程——一门提高机器学习性能的艺术
当前围绕人工智能(AI)和机器学习(ML)展开的许多讨论以模型为中心,聚焦于 ML和深度学习(DL)的最新进展。这种模型优先的方法往往对用于训练这些模型的数据关注不足,甚至完全忽视。类似MLOps的领域正迅速发展,通过系统性地训练和利用ML模型&…...

Paper解读:工作场所人机协作的团队形成:促进组织变革的目标编程模型
人工智能(AI)具有降低运营成本、提高效率和改善客户体验的潜力。 因此,在组织中组建项目团队至关重要,这样他们就会在决策过程中欢迎人工智能。 当前的技术革命要求公司快速变革,并增加了对团队在促进创新采用方面的作…...

图文深入理解Oracle Network配置管理(一)
List item 本篇图文深入介绍Oracle Network配置管理。 Oracle Network概述 Oracle Net 服务 Oracle Net 监听程序 <oracle_home>/network/admin/listener.ora <oracle_home>/network/admin/sqlnet.ora建立网络连接 要建立客户机或中间层连接,Oracle…...

leetcode-链表篇3
leetcode-61 给你一个链表的头节点 head ,旋转链表,将链表每个节点向右移动 k 个位置。 示例 1: 输入:head [1,2,3,4,5], k 2 输出:[4,5,1,2,3]示例 2: 输入:head [0,1,2], k 4 输出&#x…...

RAG(Retrieval Augmented Generation)及衍生框架:CRAG、Self-RAG与HyDe的深入探讨
近年来,随着大型语言模型(LLMs)的迅猛发展,我们在寻求更精确、更可靠的语言生成能力上取得了显著进展。其中,检索增强生成(Retrieval-Augmented Generation)作为一种创新方法,极大地…...

C语言介绍
什么是C语言 C programing language 能干什么 Hello world? 如何学C语言 no reading no learning...

损失函数篇 | YOLOv10 更换损失函数之 MPDIoU | 《2023 一种用于高效准确的边界框回归的损失函数》
论文地址:https://arxiv.org/pdf/2307.07662v1.pdf 边界框回归(Bounding Box Regression,BBR)在目标检测和实例分割中得到了广泛应用,是目标定位的重要步骤。然而,对于边界框回归的大多数现有损失函数来说,当预测的边界框与真值边界框具有相同的长宽比,但宽度和高度的…...

WMware安装WMware Tools(Linux~Ubuntu)
1、这里终端里面输入sudo apt upgrade用于更新最新的包 sudo apt upgrade 2、安装 open-vm-tools-desktop 包, Ps:这里是以为我已经安装好了。 udo apt install open-vm-tools-desktop -y3、最后重启就大功告成了 reboot 4、测试是否成功:…...
SLAM ORB-SLAM2(30)关键帧跟踪
SLAM ORB-SLAM2(30)关键帧跟踪 1. 关键帧跟踪2. TrackReferenceKeyFrame2.1. 将当前普通帧的描述子转化为BoW向量2.2. 通过词袋BoW加速当前帧与参考帧之间的特征点匹配2.3. 将上一帧的位姿态作为当前帧位姿的初始值2.4. 通过优化3D-2D的重投影误差来获得位姿2.5. 剔除优化后的…...
k8s 部署 prometheus
创建namespace prometheus-namespace.yaml apiVersion: v1 kind: Namespace metadata:name: ns-prometheus拉取镜像 docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/quay.io/prometheus/prometheus:v2.54.0prometheus配置文件configmap prometheus-configmap.yaml …...

使用VBA快速生成Excel工作表非连续列图片快照
Excel中示例数据如下图所示。 现在需要拷贝A2:A15,D2:D15,J2:J15,L2:L15,R2:R15为图片,然后粘贴到A18单元格,如下图所示。 大家都知道VBA中Range对象有CopyPicture方法可以拷贝为图片,但是如果Range对象为非连续区域,那么将产生10…...
解决GitHub下载速度慢
解决GitHub下载速度慢 方法一:使用git clone 地址 --depth 1来下载 depth 1 表示只科隆最新的一次提交,也就是默认主分支,而不是完整地克隆整个代码仓库,这样可以减少下载地数据,加快克隆操作 可以用git clone 地址 …...

【机器学习(五)】分类和回归任务-AdaBoost算法
文章目录 一、算法概念一、算法原理(一)分类算法基本思路1、训练集和权重初始化2、弱分类器的加权误差3、弱分类器的权重4、Adaboost 分类损失函数5、样本权重更新6、AdaBoost 的强分类器 (二)回归算法基本思路1、最大误差的计算2…...

【设计模式-模板】
定义 模板方法模式是一种行为设计模式,它在一个方法中定义了一个算法的骨架,并将一些步骤延迟到子类中实现。通过这种方式,模板方法允许子类在不改变算法结构的情况下重新定义算法中的某些特定步骤。 UML图 组成角色 AbstractClass&#x…...

小程序原生-列表渲染
1. 列表渲染的基础用法 <!--渲染数组列表--> <view wx:for"{{numList}}" wx:key"*this" > 序号:{{index}} - 元素:{{item}}</view> <!--渲染对象属性--> <view wx:for"{{userInfo}}" wx:key&q…...
JAVA认识异常
目录 1. 异常的概念与体系结构 1.1 异常的概念 1. 算术异常 2. 数组越界异常 3. 空指针异常 1.2 异常的分类 1. 编译时异常 2. 运行时异常 2.1 异常的处理 防御式编程 2.2 异常的捕获 2.3.1 异常声明throws 2.3.2 try-catch捕获并处理 2.3.3 finally 总结 1. 异常…...
2024年10月计划(工作为主,Ue5独立游戏为辅,)
我发现一点,就是工作很忙,比如中秋也在远程加班,周末有时也远程加班,国庆节甚至也差点去甲方工作。甚至有可能驻场。可见,小公司确实不能去。 好在,9月份时,通过渲染 除了上班时间外࿰…...
vscode里如何用git
打开vs终端执行如下: 1 初始化 Git 仓库(如果尚未初始化) git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...

(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...

深入理解JavaScript设计模式之单例模式
目录 什么是单例模式为什么需要单例模式常见应用场景包括 单例模式实现透明单例模式实现不透明单例模式用代理实现单例模式javaScript中的单例模式使用命名空间使用闭包封装私有变量 惰性单例通用的惰性单例 结语 什么是单例模式 单例模式(Singleton Pattern&#…...

【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力
引言: 在人工智能快速发展的浪潮中,快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型(LLM)。该模型代表着该领域的重大突破,通过独特方式融合思考与非思考…...

tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...

视觉slam十四讲实践部分记录——ch2、ch3
ch2 一、使用g++编译.cpp为可执行文件并运行(P30) g++ helloSLAM.cpp ./a.out运行 二、使用cmake编译 mkdir build cd build cmake .. makeCMakeCache.txt 文件仍然指向旧的目录。这表明在源代码目录中可能还存在旧的 CMakeCache.txt 文件,或者在构建过程中仍然引用了旧的路…...

使用Spring AI和MCP协议构建图片搜索服务
目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式(本地调用) SSE模式(远程调用) 4. 注册工具提…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
虚拟电厂发展三大趋势:市场化、技术主导、车网互联
市场化:从政策驱动到多元盈利 政策全面赋能 2025年4月,国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》,首次明确虚拟电厂为“独立市场主体”,提出硬性目标:2027年全国调节能力≥2000万千瓦࿰…...