Java面试题之Java的IO

1.Java中有几种类型的流

1、按照流的方向:输入流(inputStream)和输出流(outputStream)

2、按照实现功能:节点流(可以从或向一个特定的地方(节点)读写数据。如 FileReader)和处理流(是对一个

已存在的流的连接和封装,通过所封装的流的功能调用实现数据读写。如BufferedReader,处理流的构造方法总是要

带一个其他的流对象做参数。一个流对象经过其他流的多次包装,称为流的链接。)

3、按照处理数据的单位:字节流和字符流。字节流继承于 InputStream 和 OutputStream,字符流继承于

InputStreamReader 和OutputStreamWriter。

2.字节流如何转为字符流

字节输入流转字符输入流通过InputStreamReader实现,该类的构造函数可以传入InputStream对象。

字节输出流转字符输出流通过OutputStreamWriter实现,该类的构造函数可以传入OutputStream对象。 

3.如何将一个java对象序列化到文件里

在java中能够被序列化的类必须先实现Serializable接口,该接口没有任何抽象方法只是起到一个标记作用。


4.字节流和字符流的区别

看图中重点:


5.如何实现对象克隆

有两种方式。

1). 实现 Cloneable 接口并重写 Object 类中的 clone()方法;

2). 实现 Serializable 接口,通过对象的序列化和反序列化实现克隆,可以实现真正的深度克隆,代码如下。



注意:基于序列化和反序列化实现的克隆不仅仅是深度克隆,更重要的是通过泛型限定,可以检查出要克隆的对象是否支持序列化,这项检查是编译器完成的,不是在运行时抛出异常,这种是方案明显优于使用Object 类的 clone方法克隆对象。让问题在编译的时候暴露出来总是好过把问题留到运行时。

6. 什么是java序列化,如何实现java序列化

序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对对象流进行读写操作时所引发的问题。

序列化的实现:将需要被序列化的类实现 Serializable 接口,该接口没有需要实现的方法,实现Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。

你可能感兴趣的:(Java面试题之Java的IO)