序列化在IO中讀寫對象的使用
序列化就是一種用來處理對象流的機制,所謂對象流也就是將對象的內容進行流化??梢詫α骰蟮膶ο筮M行讀寫操作,也可將流化后的對象傳輸于網絡之間。序列化是為了解決在對對象流進行讀寫操作時所引發的問題。
序列化的實現:將需要被序列化的類實現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[] strtb) 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());
}
}