对象序列化与随机文件

来源:互联网 发布:淘宝卖家怎么设置会员 编辑:程序博客网 时间:2024/04/30 10:53

对象序列化与随机文件

对象的序列化ObjectInputStream

ObjectOutputStream

可以通过这两个流对象直接操作已有对象并将对象进行本地持久化存储。

存储后的对象可以进行网络传输。

两个对象的特有方法:

ObjectInputStream

Object readObject():该方法抛出异常:ClassNotFountException

ObjectOutputStream

void writeObject(Object):被写入的对象必须实现一个接口:Serializable

否则会抛出:NotSerializableException 

Serializable:该接口其实就是一个没有方法的标记接口。

用于给类指定一个UID。该UID是通过类中的可序列化成员的数字签名运算出来的一个long型的值。

只要是这些成员没有变化,那么该值每次运算都一样。

该值用于判断被序列化的对象和类文件是否兼容。

如果被序列化的对象需要被不同的类版本所兼容。可以在类中自定义UID

定义方式:static final long serialVersionUID = 42L;

注意:对应静态的成员变量,不会被序列化。

对应非静态也不想被序列化的成员而言,可以通过transient关键字修饰。

通常,这两个对象成对使用。

随机文件操作——RandomAccessFile

该对象并不是流体系中的一员。

该对象中封装了字节流,同时还封装了一个缓冲区(字节数组),通过内部的指针来操作数组中的数据。

该对象特点:

1,该对象只能操作文件,所以构造函数接收两种类型的参数。

a,字符串路径。

bFile对象。

2,该对象既可以对文件进行读取,也可以写入。

   在进行对象实例化时,必须要指定的该对象的操作模式,r rw等。

该对象中有可以直接操作基本数据类型的方法。

该对象最有特点的方法:

skipBytes():跳过指定的字节数。

seek():指定指针的位置。

getFilePointer():获取指针的位置。

通过这些方法,就可以完成对一个文件数据的随机的访问。

想读哪里就读哪里,想往哪里写就往哪里写。

该对象功能,可以读数据,可以写入数据,如果写入位置已有数据,会发生数据覆盖。也就是可以对数据进行修改。

在使用该对象时,建议数据都是有规则的。或者是分段的。

注意;该对象在实例化时,如果要操作的文件不存在,会自动建立。

如果要操作的文件存在,则不会建立,如果存在的文件有数据。

那么在没有指定指针位置的情况下,写入数据,会将文件开头的数据覆盖。