编程语言
首页 > 编程语言> > JavaIO特殊操作流

JavaIO特殊操作流

作者:互联网

目录

前言:

System:

打印流:

对象序列化流:


前言:

        大家好啊!今天给大家介绍介绍IO流里面的几个特殊操作流。

        因为博主在写一个图书管理系统,里面对于对象序列化流的应用比较多,也算是回头复习一下,这个流是蛮重要的。

System:

System类中有两个静态的成员变量:

public static final InputStream in:标准输入流。通常该流对应于键盘输入或由主机环境或用户指定的另一个输入源 
public static final PrintStream out:标准输出流。通常该流对应于键盘输入或由主机环境或用户指定的另一个输入源 

输出语句的本质:是一个标准的输出流

PrintStream ps = System.out
PrintStream类有的方法,System.out都可以使用  

打印流:

打印流分流:

字节打印流:PrintStream
字符打印流:PrintWriter

打印流的特点:

只负责输出数据,不负责读取数据
永远不会抛出IOException
有自己的特有方法

字节打印流:

PrintStream(String fileName):使用指定的文件名创建新的打印流
使用继承父类的方法写数据,查看的时候会转码;使用自己的特有方法写数据,查看的数据原样输出

可以改变输出语句的目的地:public static void setOut(PrintStream out):重新分配“标准”输出流

字符打印流:

PrintWriter(String fileName)使用指定的文件名创建一个新的PrintWriter,而不需要自动执行刷新
PrintWriter(Writer   out, boolean autoFlush)创建一个新的PrintWriter    out:字符输出流    autoFlush: 一个布尔值,如果为真,则println , printf ,或format方法将刷新输出缓冲区

对象序列化流:

对象序列化介绍:

对象序列化:就是将对象保存到磁盘中,或者在网络中传输对象
这种机制就是使用一个字节序列表示一个对象,该字节序列包含:对象的类型、对象的数据和对象中存储的属性等信息
字节序列写到文件之后,相当于文件中持久保存了一个对象的信息
反之,该字节序列还可以从文件中读取回来,重构对象,对它进行反序列化

对象序列化流: ObjectOutputStream

        将Java对象的原始数据类型和图形写入OutputStream。 可以使用ObjectInputStream读取(重构)对象。 可以通过使用流的文件来实现对象的持久存储。 如果流是网络套接字流,则可以在另一个主机上或另一个进程中重构对象。

方法:

ObjectOutputStream(OutputStream out)创建一个写入指定的OutputStream的ObjectOutputStream
void writeObject(Object obj)将指定的对象写入ObjectOutputStream

注意事项:

一个对象要想被序列化,该对象所属的类必须必须实现Serializable 接口
Serializable是一个标记接口,实现该接口,不需要重写任何方法

对象反序列化流: ObjectInputStream

        ObjectInputStream反序列化先前使用ObjectOutputStream编写的原始数据和对象  

方法:

ObjectInputStream(InputStream in)创建从指定的InputStream读取的ObjectInputStream
Object readObject()从ObjectInputStream读取一个对象

serialVersionUID:

用对象序列化流序列化了一个对象后,假如我们修改了对象所属的类文件,读取数据会抛出InvalidClassException异常。

解决方法:

重新序列化

给对象所属的类加一个serialVersionUID :private static final long serialVersionUID = 42L;

transient:

如果一个对象中的某个成员变量的值不想被序列化:

给该成员变量加transient关键字修饰,该关键字标记的成员变量不参与序列化过程。

 

标签:输出,特殊,字节,对象,打印,JavaIO,操作,序列化,out
来源: https://blog.csdn.net/tiankuihan/article/details/121424050