热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

javaio工作机制_深入分析JavaI/O工作机制

前言:IO问题是Web应用中所面临的主要问题之一。而且是任何编程语言都无法回避的问题,是整个人机交互的核心。java的IO类操作在java.io包下&#

前言 :  I/O 问题是Web 应用中所面临的主要问题之一。而且是任何编程语言都无法回避的问题,是整个人机交互的核心。

java 的I/O类操作在java.io 包下,将近80个子类, 大概可以分成四个部分,

基于字节操作的I/O接口 :InputStream  和OutputStream

基于字符操作的I/O接口:Writer 和 Reader

基于磁盘操作的I/O接口:File

基于网络操作的I/O接口:Socket

1和2 主要是传输数据的格式,后面两个则是传输数据的方式。  要么数据格式影响I/O操作,要么传输方式影响I/O操作,核心问题大致可以归为这两个 。

基于字节的I/O操作接口

16aad8fc799039241a36f01b2a10f8f0.png

InputStream类层次结构

ba83deda80a67d9512256a255a2138aa.png

OutputStream类层次结构

操作数据的方式是可以组合使用的 例如

OutputStream out = new BufferedOutputStream (new ObjectOutputStream (new FileOutputStream ("filename")));

必须要指定数据流最终写入的地方,要么写入到磁盘,要么写到网络中,

基于字符的I/O操作接口

不论是磁盘还是网络传输,最小的存储单元都是字节,而不是字符,所以,I/O操作的都是字节而不是字符,但是为什么会有操作字符的I/O 接口?

我们在程序中通常操作的数据都是字符形式(Java中char占用2字节,C/C++中 char占用1字节),为了操作方便当然会提供一个字符接口,字符到字节必须要经过编码的转换,编码转换又十分耗时,还会出现乱码问题

8a90ae2b75c8ebe7cae47dbc808246f6.png

Writer 类层次结构

Writer 类提供了一个抽象方法write(char cbuf[ ],int off,in len)

2722adb1f8864961e5fb2284817ecaac.png

Reader 类层次结构

读字符的操作接口是 int  read (char cbuf[ ],int off,in len),返回读到的n个字节数,不管是读还是写,他们都只定义了读取或写入的数据字符的方式,即怎么写,怎么读,并没有规定数据要读或写到哪里

字节与字符的转换接口

有时数据持久化和网络传输是以字节进行的,所有需要字节和字符之间的相互转换

da443830f843e5cb770a41808e0abfba.png

InputStreamReader 类是从字节到字符的转化桥梁,从InputStream 到Reader 的过程要指定编码字符集,否则会采用操作系统默认的字符集,就会出现乱码的问题,StreamDecoder就是完成从字节到字符的编码的实现类

1 try{2 StringBuffer str = newStringBuffer();3 char [] buf = new char[1024]4 FileReader f = new FileReader("filename")5 while(f.read(buf)>0){6 str.append(buf);7 }8 str.tostring();9

10 }catch(IOException e){11

12 }

FileReader 就是按照上面的工作方式来读取文件的,FileReader 类继承了InputStreamReader类,实际上是读取文件流,然后通过StreamDecoder 解码成char,这里的解码字符集是默认字符集。

磁盘I/O工作机制

1, 标准访问文件的方式

当应用程序调用read() 接口时候,操作系统检查在内核的高速缓存中有没有需要的数据,如果已经缓存了那么就直接从缓存中取出返回,如果没有,则从磁盘中读取,然后缓存在操作系统的缓存中。

写入的方式是,用户的应用程序调用write() 接口将数据从用户地址空间复制到内核地址空间的缓存中,这时对用户程序来说,写操作就已经完成了,至于什么时候写入到磁盘中去,由操作系统决定,除非显示的调用了sync同步命令。

e6e9fa186dbcff05c33e8bb9ba8ce54b.png

标准文件访问方式

2, 直接I/O的方式

即应用程序直接访问磁盘数据而不经过操作系统内核数据缓冲区,这样减少了一次从内核缓冲区到用户程序缓存的复制, 这种访问方式通常在对数据的缓存管理由应用程序实现的数据库管理系统中,在数据库管理系统中,系统明确的知道应该缓存哪些数据,应该失效哪些数据,还可以对一些热点数据做预加载,提前将数据加载到内存,可以加速数据访问效率,在这些情况下,如果由操作系统进行缓存就很难做到,操作系统不知道哪些是热点数据,哪些数据只会访问一次就不会再访问,操作系统只是简单的缓存最近一次从磁盘读取的数据,

但是直接I/O的话也会有负面影响: 如果访问的数据不在应用程序缓存中,那么每次数据都要直接从磁盘进行预加载,这种直接加载会十分缓慢,通常直接I/O 与异步I/O结合使用会有比较好的性能。

5869ecabd7925894733761bc6c3b0dee.png

直接I/O 的方式

3, 同步访问文件的方式

同步访问文件的方式比较容易理解,就是数据读取和写入都是同步操作的,与标准文件访问方式不同的是,只有当数据被成功写到磁盘时才返回给应用程序成功的标志, 这种访问方式的性能比较差,只有在对数据安全性较高的场景中才会使用,而且通常这种操作方式的硬件都是定制的。

4f37b323b10689dbcb01bcb8b59df46c.png

同步访问文件的方式

4, 异步访问文件的方式

异步访问文件的方式是当访问数据的线程发出请求之后,线程会接着去处理其他事,而不是阻塞等待,当请求的数据返回之后,继续处理下面的操作, 这种访问文件的方式可以明显的提高应用程序的效率,但是不会改变访问文件的效率

9ad6b62cfe3fa1fabbe575c57b5ad846.png

异步访问文件的方式

5, 内存映射的方式

内存映射是指操作系统将内存中的某一块区域与磁盘中的文件关联起来,当要访问内存中的一段数据的时候,转换为访问文件的某一段数据,这种方式的目的同样是减少数据从内核空间缓存到用户空间缓存的数据复制操作,因为这两个数据空间的数据是共享的。

6983fcb888ae728da4a60bfad3a51648.png

内存映射方式



推荐阅读
  • 本文详细探讨了Java中的ClassLoader类加载器的工作原理,包括其如何将class文件加载至JVM中,以及JVM启动时的动态加载策略。文章还介绍了JVM内置的三种类加载器及其工作方式,并解释了类加载器的继承关系和双亲委托机制。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • This post discusses an issue encountered while using the @name annotation in documentation generation, specifically regarding nested class processing and unexpected output. ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 软件工程课堂测试2
    要做一个简单的保存网页界面,首先用jsp写出保存界面,本次界面比较简单,首先是三个提示语,后面是三个输入框,然 ... [详细]
  • 本文深入探讨了UNIX/Linux系统中的进程间通信(IPC)机制,包括消息传递、同步和共享内存等。详细介绍了管道(Pipe)、有名管道(FIFO)、Posix和System V消息队列、互斥锁与条件变量、读写锁、信号量以及共享内存的使用方法和应用场景。 ... [详细]
  • 2017-2018年度《网络编程与安全》第五次实验报告
    本报告详细记录了2017-2018学年《网络编程与安全》课程第五次实验的具体内容、实验过程、遇到的问题及解决方案。 ... [详细]
  • 本文探讨了如何使用pg-promise库在PostgreSQL中高效地批量插入多条记录,包括通过事务和单一查询两种方法。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
  • 探讨ChatGPT在法律和版权方面的潜在风险及影响,分析其作为内容创造工具的合法性和合规性。 ... [详细]
  • springMVC JRS303验证 ... [详细]
  • 近期我们开发了一款包含天气预报功能的万年历应用,为了满足这一需求,团队花费数日时间精心打造并测试了一个稳定可靠的天气API接口,现正式对外开放。 ... [详细]
author-avatar
叶子美容美体养生馆os
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有