BufferReader属于哪种流,主要是用来做什么,里面有哪些方法?
BufferReader属于处理流中的缓冲流,可以将读取的内容存在内存里面,比Reader类多了一个readLine()方法。
这篇博文提供了BufferReader类的详细介绍
Java中,什么是实现对象序列化?如何实现对象序列化?
-
对象序列化可以将一个对象保存到一个文件,可以将通过流的方式在网络上传输,可以将文件的内容读取转化为一个对象。
-
所谓对象流也就是将对象的内容流化,可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了解决在对象流进行读写操作时引发的问题。
-
序列化的实现:将需要被序列化的类实现serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数obj的对象写出,要恢复的话则用输入流。
示例
public class User implements java.io.Serializable {
public String username;
public String password;
public transient String message;
public boolean login(String username,String password){
return this.username.equals(username) && this.password.equals(password);
}
}
请注意,一个类的对象要想序列化成功,必须满足两个条件:
-
该类必须实现 java.io.Serializable 接口。
-
该类的所有属性必须是可序列化的。如果有一个属性不是可序列化的,则该属性必须注明是短暂的。
序列化对象
ObjectOutputStream 类用来序列化一个对象,如下的 SerializeDemo 例子实例化了一个 Employee 对象,并将该对象序列化到一个文件中。
该程序执行后,就创建了一个名为 employee.ser 文件。该程序没有任何输出,但是你可以通过代码研读来理解程序的作用。
注意: 当序列化一个对象到文件时, 按照 Java 的标准约定是给文件一个 .ser 扩展名。
序列化对象
import java.io.*;
public class SerializeDemo {
public static void main(String [] args) {
User user=new User();
user.username="root";
user.password="123456";
user.message="java serialize";
try{
FileOutputStream fileOut =new FileOutputStream("/tmp/user.giao");
ObjectOutputStream out = new ObjectOutputStream(fileOut);
out.writeObject(e);
out.close();
fileOut.close();
}catch(IOException i) {
i.printStackTrace();
}
}
}
反序列化对象
import java.io.*;
public class DeserializeDemo {
public static void main(String [] args) {
User user=null;
try{
FileInputStream fileIn = new FileInputStream("/tmp/user.giao");
ObjectInputStream in = new ObjectInputStream(fileIn);
user = (Employee) in.readObject();
in.close();
fileIn.close();
}catch(IOException i){
i.printStackTrace();
return;
}catch(ClassNotFoundException c){
System.out.println("User class not found");
c.printStackTrace();
return;
}
System.out.println(user.username);
System.out.println(user.password);
System.out.println(user.message);
System.out.println(user.login("root","123456"));
}
}
运行结果
root
123456
""
true
这里要注意以下要点:
-
readObject() 方法中的 try/catch代码块尝试捕获 ClassNotFoundException 异常。对于 JVM 可以反序列化对象,它必须是能够找到字节码的类。如果JVM在反序列化对象的过程中找不到该类,则抛出一个 ClassNotFoundException 异常。
-
readObject() 方法的返回值被转化成 User引用。
-
当对象被序列化时,属性 message 的值为 “java serialize”,但是因为该属性是短暂的,该值没有被发送到输出流。所以反序列化后 User对象的 message 属性为 0。