【IO专栏002】JAVA I/O的工作机制

1.引言

I/O问题是任何编程语言都无法回避的问题,可以说I/O问题是整个人机交互的核心问题,因为I/O是机器获取和交换信息的主要渠道。

2.JAVA I/O 操作类 概括

  1. 基于字节操作的I/O接口:InputStream 和OutputStream
  2. 基于字符操作的I/O接口:Write 和Reader
  3. 基于磁盘操作的I/O接口:File
  4. 基于网络操作的I/O接口:Socket

前两组主要是传输数据的数据格式,后两组主要是传输数据的方式,虽然Socket累并不在java.io包下,但是也仍然需要将它划分到一起,因为I/O的核心问题要么是数据格式影响I/O操作,要么是传输方式影响I/O操作,也就是将什么样的数据写到什么地方的问题。I/O只是人机或者机器与机器交互的手段,除了它们能够完成这个交互功能外,我们关注的是如何提高交互效率,而数据格式和传输方式是影响效率的最核心因素。

2.1 基于字符的I/O操作总结

不管是磁盘还是网络传输,最小的存储单元都是字节,而不是字符,所以I/O操作都是字节操作而不是字符,但是为什么有操作字符的I/O接口呢?这是因为在我们的程序中通常操作的数据都是字符形式的,为了操作翻倍当然要提供一个直接写字符的I/O接口,仅此而已。我们知道从字符到字节必须要经过编码转换,而这个编码又非常耗时,而且搞不好,经常出现乱码问题。

3磁盘I/O的工作机制

  我们知道,读取和写入文件I/O操作都是调用操作系统提供的接口,因为磁盘设备是由操作系统管理的,应用程序要访问物理设备只能通过操作系统调用的方式来工作。读和写分别对应read()和write()两个系统调用。而只要是系统调用就可能存在内核空间地址和用户空间地址的切换问题,这是操作系统为了保护系统本身的运行安全,而将内核程序运行使用的呢次空间和用户程序运行的内存空间进行隔离造成的。但是这样虽然保证了内核程序运行的安全,但是也必然存在数据可能需要从内核空间向用户空间复制的问题。

如果遇到了非常耗时的操作,如磁盘I/O,数据从磁盘复制到内核空间 ,然后又从内核空间复制到用户空间,将会非常缓慢。这时候操作系统为了加速IO访问,在内核空间使用缓存机制,也就是将从磁盘读取的文件按照一定的组织方式进行缓存,如果用户程序访问的是同一段磁盘地址的空间数据,那么操作系统将从内核缓存中直接取出返回给用户程序,这样可以减小IO的响应时间。

3.1几种访问文件的方式

1.标准访问文件的方式

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

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

2.直接I/O的方式

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

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

3.同步访问文件的方式

同步访问文件的方式比较容易理解,就是数据的读取和写入都是同步操做的,它与标准文件方式不同的是,只有当数据被成功写到磁盘时,才会返回给应用程序成功的标志。

这种访问文件的方式性能比较差,只有在一些堆数据安全性要求比较高的场景中才会使用,而且通常这种操作发您的硬件都是定制的。

4.异步访问文件的方式

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

5.内存映射的方式

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

 

参考《深入分析JAVA WEB 技术内幕》修订版

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值