JAVA序列化在IO中读写对象的使用
2013-09-12 22:58
477 查看
序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对对象流进行读写操作时所引发的问题。
序列化的实现:将需要被序列化的类实现Serializable接口,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
写对象和读对象的时候一定要使用序列化:
序列化的实现:将需要被序列化的类实现Serializable接口,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
写对象和读对象的时候一定要使用序列化:
import java.io.*; class Product implements Serializable { private static final long serialVersionUID = 1L; private float price; private float tax; public Product(float price) { this.price = price; tax = (float)(price*0.20); } public String toString() { return "price:"+price+",tax:"+tax; } } public class CmdDemo { public static void main(String[] str) throws Exception { Product p1 = new Product(100); ObjectOutputStream os = new ObjectOutputStream(new FileOutputStream("d:\\product.txt")); os.writeObject(p1); os.close(); ObjectInputStream is = new ObjectInputStream(new FileInputStream("d:\\product.txt")); Product p2 = (Product) is.readObject(); System.out.println(p2.toString()); } }
相关文章推荐
- java使用IO对象流进行数据读写
- python的io 与java的io流的使用及对象的序列化
- java对象序列化java.io.Serializable 接口实践
- java IO之Print、Scanner和对象序列化
- java 对象序列化使用
- 用java的i/o读写文件,举一反三看清io的使用
- JAVA 对象序列化(三)——transient以及Externalizable的一种替代方法(使用Serializable)
- Java使用ObjectOutputStream和ObjectInputStream序列号对象报java.io.EOFException异常的解决方法
- 将java对象存储到redis数据库(使用序列化和反序列化)
- Java IO操作——简单了解RandomAccessFile随机读写文件操作类的使用
- Java IO之对象序列化(二)
- 对象序列化中java.io.InvalidClassException的解决方法
- 使用Java序列化把对象存储到文件中,再从文件中读出来
- Java IO--对象序列化Serializable、ObjectOutputStream、ObjectInputStream、transient
- 介绍Java对象序列化使用基础
- Java IO详解(六)------序列化与反序列化(对象流)
- java提高篇-----使用序列化实现对象的拷贝 (深拷贝)
- java-IO操作——使用带有缓冲的字符流读写数据
- JavaIO 6—对象的序列化
- 聊聊序列化(二)使用sun.misc.Unsafe绕过new机制来创建Java对象