java中静态不能被序列化的疑问 10
importjava.io.ObjectOutputStream;importjava.io.IOException;importjava.io.FileOutputSt...
import java.io.ObjectOutputStream;
import java.io.IOException;
import java.io.FileOutputStream;
import java.io.FileInputStream;
import java.io.ObjectInputStream;
class ObjectStreamDemo{
public static void writeObj()throws IOException{
ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("Person.txt"));//创建写入指定 OutputStream 的 ObjectOutputStream。
//此构造方法将序列化流部分写入底层流
oos.writeObject(new Person("zhang",12,"haha"));//将指定的对象写入 ObjectOutputStream
/*
对象的类、类的签名(SerialVersionUID),以及类及其所有父类的非瞬态和非静态字段的值都将被写入
*/
oos.close();
}
public static void readObj()throws IOException,ClassNotFoundException{
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("Person.txt"));//创建从指定 InputStream 读取的 ObjectInputStream。
Person p=(Person)ois.readObject();//将读取流中的一个对象返回,当有多个对象可以采用循环读取
//注意该方法上声明两个异常(IOException,ClassNotFoundException)
System.out.println(p.toString());
}
public static void main(String[] args)throws IOException,ClassNotFoundException{
writeObj();
readObj();
}
}
import java.io.Serializable;
public class Person implements Serializable{
private static final long serialVersionUID=100L;
private String name;
int age;
private static String country="cn";
public Person(String name,int age,String country){
this.name=name;
this.age=age;
this.country=country;//非静态可以访问静态
}
public String toString(){
return name+"..."+age+"..."+country;
}
}
问题就是:结果是 zhang...12...haha
但是如果:
先writeObj(),然后readObj()
结果zhang...12...cn (这个是正确的)
麻烦大神门详细解释下,出现上述情况的原因. 展开
import java.io.IOException;
import java.io.FileOutputStream;
import java.io.FileInputStream;
import java.io.ObjectInputStream;
class ObjectStreamDemo{
public static void writeObj()throws IOException{
ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("Person.txt"));//创建写入指定 OutputStream 的 ObjectOutputStream。
//此构造方法将序列化流部分写入底层流
oos.writeObject(new Person("zhang",12,"haha"));//将指定的对象写入 ObjectOutputStream
/*
对象的类、类的签名(SerialVersionUID),以及类及其所有父类的非瞬态和非静态字段的值都将被写入
*/
oos.close();
}
public static void readObj()throws IOException,ClassNotFoundException{
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("Person.txt"));//创建从指定 InputStream 读取的 ObjectInputStream。
Person p=(Person)ois.readObject();//将读取流中的一个对象返回,当有多个对象可以采用循环读取
//注意该方法上声明两个异常(IOException,ClassNotFoundException)
System.out.println(p.toString());
}
public static void main(String[] args)throws IOException,ClassNotFoundException{
writeObj();
readObj();
}
}
import java.io.Serializable;
public class Person implements Serializable{
private static final long serialVersionUID=100L;
private String name;
int age;
private static String country="cn";
public Person(String name,int age,String country){
this.name=name;
this.age=age;
this.country=country;//非静态可以访问静态
}
public String toString(){
return name+"..."+age+"..."+country;
}
}
问题就是:结果是 zhang...12...haha
但是如果:
先writeObj(),然后readObj()
结果zhang...12...cn (这个是正确的)
麻烦大神门详细解释下,出现上述情况的原因. 展开
4个回答
展开全部
原因很简单,对象流中的readObject()不会调用构造函数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-07-03
展开全部
静态不能。想做,就对各个属性做序列化。
追问
你运行试试
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2022-02-10
展开全部
zhang...12...haha:
该结果的出现是由于main中连续进行了序列化和反序列化,都是在同一个JVM中进行的,即使反序列化时无法获取country,但在序列化时设置了country=haha,所以可以取到haha。这是由于static可以在同一个JVM中共享变量。
zhang...12...cn:
对比上述方法,使用了不同的JVM来进行序列化 / 反序列化。在序列化时,先取到了静态的haha,后面的非静态不会被取走,所以在后面修改这个属性是没意义的,无法被序列化。
该结果的出现是由于main中连续进行了序列化和反序列化,都是在同一个JVM中进行的,即使反序列化时无法获取country,但在序列化时设置了country=haha,所以可以取到haha。这是由于static可以在同一个JVM中共享变量。
zhang...12...cn:
对比上述方法,使用了不同的JVM来进行序列化 / 反序列化。在序列化时,先取到了静态的haha,后面的非静态不会被取走,所以在后面修改这个属性是没意义的,无法被序列化。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询