博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入分析Java Web技术(2) IO
阅读量:5938 次
发布时间:2019-06-19

本文共 944 字,大约阅读时间需要 3 分钟。

IO是当今Web面临的主要问题之一,可以说,大部分web应用的瓶颈都是IO的瓶颈。

Java的IO类是java.io.它包含有80多个类,分为4大部分:

  • 基于字节操作: InputStream,OutputStream
  • 基于字符操作: Writer 和Reader
  • 基于磁盘操作: File
  • 基于网络操作: Socket

 

一、基于字符的IO操作

不管是网络传输还是磁盘,最小的存储单元都是字节,而不是字符,那为什么还有字符的处理呢?这是因为我们程序中操作的单位一般都是字符,而不是字节,而将字符转换为字节又是需要时间的,并且编解码的问题经常容易引起乱码。

InputStreamReader是将字节到字符进行转换的桥梁。另外,需要注意的是要指定转换的字符集,否则非常容易引起乱码的问题。而StreamDecoder是完成字节到字符解码的类,

这是一个读取文件的实现方式,FileReader继承了InputStreamer,将一个文件流读入字符集buf中,通过StreamDecoder完成字节的解码操作。

访问文件的方式:

(1)标准访问方式:

 

 

    (读操作  》)

磁盘 --  缓存 -- 内核空间

    (《 写操作)

(2)直接IO操作

(3)同步访问

顾名思义,文件的读写操作是同步的,必须等到文件读写成功后才会返回标志,一般用于特别重要的数据的读写

(4)异步访问

和同步访问相反,当读写线程发出请求之后,会接着去处理其他的事情,而不会阻塞。这种访问方式会提高应用程序的了效率,但不会改变文件的读写效率

(5)内存映射

Java读写磁盘文件

Java中通常的File 并不代表一个真实存在的文件对象,当你制定一个描述符的时候,他就会返回一个代表这个路径的虚拟对象,它可能是一个真实存在的对象,也可能是一个包含多个文件的目录。只有在读写文件的时候,我们才会检查是否存在这个文件 。

序列化

Java序列化是将一个Java对象转换为一串二进制字符数组,通过转移或保存字节数组达到持久化的目的。

 

 未完 ......

 

关键字:  序列化

 

参考: 《深入分析Java 技术内幕》

转载于:https://www.cnblogs.com/CBDoctor/p/4232516.html

你可能感兴趣的文章
Apache Spark 2.0预览: 机器学习模型持久化
查看>>
技术指导实践指南
查看>>
GitHub上的编程语言:JavaScript领衔Java次之
查看>>
微软发布了Spartan项目的细节,并证实了某些流言
查看>>
全面了解大数据“三驾马车”的开源实现
查看>>
.NET Core 2.1预览分层编译特性
查看>>
公有云还能信任吗?Azure遭雷击中断超过一天
查看>>
量子计算竞速时代,如何拨动时间的指针
查看>>
统计php脚本执行时间的php扩展
查看>>
华中科大提出EAT-NAS方法:提升大规模神经模型搜索速度
查看>>
Spring框架5.1将提供对Java 11的支持
查看>>
切勿版本化Web API
查看>>
SpringOne 2017第二日:Juergen Hoeller的演讲
查看>>
Hyperledger Composer评测
查看>>
差分隐私简介
查看>>
Java将弃用finalize()方法?
查看>>
Apache Pulsar中的地域复制,第1篇:概念和功能
查看>>
干净架构在 Web 服务开发中的实践
查看>>
云原生的浪潮下,为什么运维人员适合学习Go语言?
查看>>
Puppet 4 性能提升超2倍,升级前应该你知悉的变化
查看>>