总是记不住java的IO流用法?用N个问题教你掌握java IO流
摘要:Java IO 体系看起来类很多,感觉很复杂,但其实是 IO 涉及的因素太多了。在设计 IO 相关的类时,编写者也不是从同一个方面考虑的,所以会给人一种很乱的感觉,并且还有设计模式的使用,更加难以使用这些 IO 类,所以特地对 Java 的 IO 做一个总结。
本文分享自华为云社区《总是记不住java的IO流用法?用N个问题教你掌握java IO流》,原文作者:breakDraw 。
Java IO 体系看起来类很多,感觉很复杂,但其实是 IO 涉及的因素太多了。在设计 IO 相关的类时,编写者也不是从同一个方面考虑的,所以会给人一种很乱的感觉,并且还有设计模式的使用,更加难以使用这些 IO 类,所以特地对 Java 的 IO 做一个总结。
文件API
Q: File类可以用来做目录操作吗?
A:可以。
File对象本身可以是目录。调用file.mkdirs()即可创建目录。
Q:直接调用file.delete()可以删除目录吗?
A:如果是文件或者空目录,可以直接删除。
但如果目录中有文件或者子目录,则必须递归删除。
private static boolean deleteDir(File dir) { if (dir.isDirectory()) { String[] children = dir.list(); //递归删除目录中的子目录下 for (int i=0; i<children.length; i++) { boolean success = deleteDir(new File(dir, children[i])); if (!success) { return false; } } } // 目录此时为空,可以删除 return dir.delete(); }
Q: 有哪些方法判断给定路径下文件是否存在?
A:
1.File类的exists方法: file.exist(string)
File testFile = new File(testFilePath); if(!testFile .exists()) {...}
2.File类的静态exist方法, File.exist(Path path)
Path filePath = Paths.get(testFilePath); if (Files.exists(filePath) {...}
注意静态方法和非静态方法的区别
字节输入流InputStream
说一下以下这些特点对应哪些Input Stream类
- 字节数组char[] 作为输入源的Input Stream类是——ByteArrayInputStream
- 用文件作为输入源的Input Stream类是?——FileInputStream
- 用字符串作为输入源的是?——StringBufferInputStream
- 用于多线程之间管道通信的输入源是——PipeInputStream
Q: FilterInputStream是什么?
A: 用于装饰上面这些输入流的,可以叠加,每装饰一层就相当于增加了1个功能。
InputStream inputStream = new FilterInputStream(InputStream)
以下这些特点分别对应哪些FilterInputStream?
- 装饰后,不仅可读字符串,还可读取例如int、long等java基本类型的是————DataInputStream
DataInputStream里面会支持readInt、readLong等方法。 - 装饰后,支持分批缓冲读取读取的是————BufferedInputStream
创建BufferedInputStream时,我们会通过它的构造函数指定某个输入流为参数。BufferedInputStream会将该输入流数据分批读取,每次读取一部分到缓冲中;操作完缓冲中的这部分数据之后,再从输入流中读取下一部分的数据。 - 其他:
PushbackInputStream: 具有1个能回退上一个字节的缓冲区
ObjectInputStream : 一般用于反序列化读入
LineNumberInputStream: 可跟踪输入流中的行号
字节输出流OutputStream
OutputStream包含
ByteArrayOutputStream 输出到缓冲区
FileOutputStream 写到文件
PipedOutputStream 写入管道
FilterOutputStream
而FilterOutputStream 包含
- DataOutputStream (可以out.writexxx各种类型的数据,writeDouble, writeUTF, reader也一样,可以读想要的数据类型)、
- PringtStream (输出到文件用这个, 该类.println(str)即可写入文件)
- BufferOutputString
FileOutputStream相关
Q:new FileOutputStream(name, true),这个构造里的true参数是做什么用的?
A:是否支持在文件末追加的意思。
默认是false,指的是覆盖整个文本。
如果设置成true,会在要写入的文件后面追加本次写入的内容。
Q:
BufferOutputStream相关概念(其实是考缓冲区是否需要刷新之类的问题)
- BufferOutputStream里的flush()方法是做什么的?
- BufferOutputStream调用close后,会触发flush()来刷新缓冲区吗?
- BufferOutputStream调用close可能会丢数据吗?
- BufferOutputStream多次调用close会报错吗?
A:
- flush把缓冲区里的数据写入文件,并刷新缓冲区
- close关闭此输出流并释放与此相关联的任何系统资源, 会调用flush,除了flushBuffer,还会调用父类的flush。
- 不会丢数据,因为上面这条原因。
- 多次调用不会报错。
Reader和Writer
Q: Reader/Writer和InputStream/OutputStream的区别?
A:
- InputStream是表示 字节输入流 的所有类的超类
Reader是用于读取 字符流 的抽象类
InputStream提供的是字节流的读取,而非文本读取,这是和Reader类的根本区别。
即用Reader读取出来的是char数组或者String ,使用InputStream读取出来的是byte数组。 - Reader/Writer提供兼容Unicode、面向字符的IO功能,为了国际化
- 用reader读取标准输入:
BufferedReader bufr = new BufferedReader(new InputStreamReader(http://System.in)); - 用Writer进行标准输出:
BufferedWriter bufw = new BufferedWriter(new OutputStreamWriter(System.out));
设置编码:
InputStreamReader isr = new InputStreamReader(new FileInputStream(file), "UTF-8"); BufferedReader read = new BufferedReader(isr);
序列化问题
Q: 对某对象进行序列化时, 如何让里面某个敏感成员不被序列化?
A:
- 方法一:可使用transient关键字处理那个敏感成员
- 方法二:可以通过覆盖Serializable接口的writeObject和readObject来实现序列化, 但是方法签名必须是private void writeObject(ObjetOutputStream stream) throw IOException;
- 方法三: 实现Externalizable接口,可自定义实现writeExternal以及readExternal方法
Q: Externalizable和Serializable哪个快?
A: Externalizable更快。
Q: Externalizable需要产生序列化ID吗?
A: 采用Externalizable无需产生序列化ID(serialVersionUID)~而Serializable接口则需要
参考资料
https://blog.csdn.net/qq_26222859/article/details/50994113
https://blog.csdn.net/weixin_44117272/article/details/90767074
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
饿了么EMonitor演进史
序言 时间回到2008年,还在上海交通大学上学的张旭豪、康嘉等人在上海创办了饿了么,从校园外卖场景出发,饿了么一步一步发展壮大,成为外卖行业的领头羊。2017年8月饿了么并购百度外卖,强强合并,继续开疆扩土。2018年饿了么加入阿里巴巴大家庭,与口碑融合成立阿里巴巴本地生活公司。“爱什么,来什么”,是饿了么对用户不变的承诺。 饿了么的技术也伴随着业务的飞速增长也不断突飞猛进。据公开报道,2014年5月的日订单量只有10万,但短短几个月之后就冲到了日订单百万,到当今日订单上千万单。在短短几年的技术发展历程上,饿了么的技术体系、稳定性建设、技术文化建设等都有长足的发展。各位可查看《饿了么技术往事》一探其中发展历程,在此不再赘述: 《饿了么技术往事(上)》 《饿了么技术往事(中)》 《饿了么技术往事(下)》 而可观测性作为技术体系的核心环节之一,也跟随饿了么技术的飞速发展,不断自我革新,从“全链路可观测性ETrace”扩展到“多活下的可观测性体系ETrace”,发展成目前“一站式可观测性平台EMonitor”。 EMonitor经过5年的多次迭代,现在已经建成了集指标数据、链路追踪、可视化面...
- 下一篇
python 大型项目神器实战
点击python编程从入门到实践,置顶 公众号重磅 python入门资料,第一时间送达 读完需要10分钟 速读仅需 4 分钟 / python 生产实战 python 大型项目神器实战 / 在 fastapi 中有一个强大并且简单易懂的系统:依赖注入系统 1 什么是依赖注入 依赖注入首先意味着在程序中我们的代码可以声明一些它必须依赖的项:我们称之为 dependencies,也就是依赖项。然后,在实际运行中,fastapi 会把所有需要的依赖项提供给你的代码,称之为注入依赖项。 一句话简单解释:原本接受各种参数来构造一个对象,现在只接受一个参数这个参数是已经实例化的对象,对象的『依赖』是注入进来的,而和它的构造方式解耦了。构造它这个『控制』操作也交给了第三方。 1.1 依赖注入适用场景列举: 1.业务逻辑复用 2.共享数据库连接 3.安全机制、权限校验、角色管理等 所有上述使用场景,借助于依赖注入可提高代码复用率,减少代码重复。 2 依赖注入实现方案 在看具体的实现依赖注入之前我们先从流程上来理解一下整个数据流转。当一个新的...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装Docker,最新的服务器搭配容器使用
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8编译安装MySQL8.0.19
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2整合Redis,开启缓存,提高访问速度
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Hadoop3单机部署,实现最简伪集群
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS6,7,8上安装Nginx,支持https2.0的开启