Java高级特性增强-NIO

2024-09-06 22:38
文章标签 java 特性 高级 nio 增强

本文主要是介绍Java高级特性增强-NIO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


GitHub:https://github.com/wangzhiwubigdata/God-Of-BigData

                   关注公众号,内推,面试,资源下载,关注更多大数据技术~大数据成神之路~预计更新500+篇文章,已经更新50+篇~ 

**Java高级特性增强-NIO

本部分网络上有大量的资源可以参考,在这里做了部分整理并做了部分勘误,感谢前辈的付出,每节文章末尾有引用列表~


写在所有文字的前面:作者在此特别推荐Google排名第一的关于NIO的文章:
http://tutorials.jenkov.com/java-nio/index.html
虽然是英文的,但是看下来并不困难。后面如果各位看官呼声很高,作者会翻译这一系列文章。

本文作者SnailClimb
https://www.jianshu.com/nb/18340870

NIO概览

从Java IO入手

先看一张网上流传的http://java.io包的类结构图:
3db10ad6b31d95ebfa36d39645e342fc.png
当你看到这幅图的时候,我相信,你跟我一样内心是崩溃的。
有些人不怕枯燥,不怕寂寞,硬着头皮看源码,但是,能坚持下去全部看完的又有几个呢!
然而,就算源码全部看完看懂,过不了几天,脑子里也会变成一团浆糊。
因为这里的类实在太多了。可能我们反复看,反复记,也很难做到清晰明白。
他就像是一块超级硬的骨头,怎么啃都啃不烂。
面对这样的做法,要坚决对他说,NO。

我的做法是找出他们的共性,给他们分类,只记典型,触类旁通。
上面的图虽然有分类,但是还不够细,而且没有总结出方便记忆的规律,所以我们要重新整理和归类。
这篇文章中,使用了两种分时给他们分组,目的是更全面的了解共性,帮助记忆。

分类一:按操作方式(类结构)

字节流和字符流:
字节流:以字节为单位,每次次读入或读出是8位数据。可以读任何类型数据。
字符流:以字符为单位,每次次读入或读出是16位数据。其只能读取字符类型数据。
输出流和输入流:
输出流:从内存读出到文件。只能进行写操作。
输入流:从文件读入到内存。只能进行读操作。
注意: 这里的出和入,都是相对于系统内存而言的。
节点流和处理流:
节点流:直接与数据源相连,读入或读出。
处理流:与节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。
**为什么要有处理流?**直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。
根据以上分类,以及jdk的说明,我们可以画出更详细的类结构图,如下:
08a43f0086bd0b2f2c6adbe12ba53203.jpeg
分类说明:
1) 输入字节流InputStream:

ByteArrayInputStream、StringBufferInputStream、FileInputStream 是三种基本的介质流,它们分别从Byte 数组、StringBuffer、和本地文件中读取数据。

PipedInputStream 是从与其它线程共用的管道中读取数据。PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操作。主要用于线程操作。

DataInputStream: 将基础数据类型读取出来

ObjectInputStream 和所有 FilterInputStream 的子类都是装饰流(装饰器模式的主角)。

2)输出字节流OutputStream:

ByteArrayOutputStream、FileOutputStream: 是两种基本的介质流,它们分别向- Byte 数组、和本地文件中写入数据。

PipedOutputStream 是向与其它线程共用的管道中写入数据。

DataOutputStream 将基础数据类型写入到文件中

ObjectOutputStream 和所有 FilterOutputStream 的子类都是装饰流。

节流的输入和输出类结构图:
ad1daa76924b325f7f5a5b580c5d5872.png
3)字符输入流Reader::

FileReader、CharReader、StringReader 是三种基本的介质流,它们分在本地文件、Char 数组、String中读取数据。

PipedReader:是从与其它线程共用的管道中读取数据

BufferedReader :加缓冲功能,避免频繁读写硬盘

InputStreamReader: 是一个连接字节流和字符流的桥梁,它将字节流转变为字符流。

4)字符输出流Writer:

StringWriter:向String 中写入数据。

CharArrayWriter:实现一个可用作字符输入流的字符缓冲区

PipedWriter:是向与其它线程共用的管道中写入数据

BufferedWriter : 增加缓冲功能,避免频繁读写硬盘。

PrintWriter 和PrintStream 将对象的格式表示打印到文本输出流。 极其类似,功能和使用也非常相似

OutputStreamWriter: 是OutputStream 到Writer 转换的桥梁,它的子类FileWriter 其实就是一个实现此功能的具体类(具体可以研究一SourceCode)。功能和使用和OutputStream 极其类似,后面会有它们的对应图。

字符流的输入和输出类结构图:
952c1fdeadfaeb2ed13a785208e0aea2.png

分类二:按操作对象

2539ba1fc433a54b14cebfc79019c2ba.jpeg
分类说明:
对文件进行操作(节点流):

  • FileInputStream(字节输入流)
  • FileOutputStream(字节输出流)
  • FileReader(字符输入流)
  • FileWriter(字符输出流)

对管道进行操作(节点流):

  • PipedInputStream(字节输入流)
  • PipedOutStream(字节输出流)
  • PipedReader(字符输入流)
  • PipedWriter(字符输出流)
  • PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操作。主要用于线程操作。

字节/字符数组流(节点流):

  • ByteArrayInputStream
  • ByteArrayOutputStream
  • CharArrayReader
  • CharArrayWriter

除了上述三种是节点流,其他都是处理流,需要跟节点流配合使用。

Buffered缓冲流(处理流):
带缓冲区的处理流,缓冲区的作用的主要目的是:避免每次和硬盘打交道,提高数据访问的效率。

  • BufferedInputStream
  • BufferedOutputStream
  • BufferedReader
  • BufferedWriter

转化流(处理流):

  • InputStreamReader:把字节转化成字符;
  • OutputStreamWriter:把字节转化成字符。

基本类型数据流(处理流):用于操作基本数据类型值。
因为平时若是我们输出一个8个字节的long类型或4个字节的float类型,那怎么办呢?可以一个字节一个字节输出,也可以把转换成字符串输出,但是这样转换费时间,若是直接输出该多好啊,因此这个数据流就解决了我们输出数据类型的困难。数据流可以直接输出float类型或long类型,提高了数据读写的效率。

  • DataInputStream
  • DataOutputStream

打印流(处理流):

一般是打印到控制台,可以进行控制打印的地方。

  • PrintStream
  • PrintWriter

对象流(处理流):

把封装的对象直接输出,而不是一个个在转换成字符串再输出。

  • ObjectInputStream,对象反序列化
  • ObjectOutputStream,对象序列化

合并流(处理流):

  • SequenceInputStream:可以认为是一个工具类,将两个或者多个输入流当成一个输入流依次读取
其他类:File

File类是对文件系统中文件以及文件夹进行封装的对象,可以通过对象的思想来操作文件和文件夹。 File类保存文件或目录的各种元数据信息,包括文件名、文件长度、最后修改时间、是否可读、获取当前文件的路径名,判断指定文件是否存在、获得当前目录中的文件列表,创建、删除文件和目录等方法。

其他类:RandomAccessFile

该对象并不是流体系中的一员,其封装了字节流,同时还封装了一个缓冲区(字符数组),通过内部的指针来操作字符数组中的数据。 该对象特点:
该对象只能操作文件,所以构造函数接收两种类型的参数:a.字符串文件路径;b.File对象。
该对象既可以对文件进行读操作,也能进行写操作,在进行对象实例化时可指定操作模式(r,rw)。
注意:IO中的很多内容都可以使用NIO完成,这些知识点大家知道就好,使用的话还是尽量使用NIO/AIO。

这篇关于Java高级特性增强-NIO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143316

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input