java :object流

import javax.management.remote.rmi.RMIConnectionImpl;
import java.io.*;
 class TV implements Serializable {
     String name;
     transient int price ;
    public void  setName(String s){
        name=s;
    }
    public void setPrice(int n){
        price =n;
    }
    public String getName(){
        return name;
    }
    public int getPrice(){
        return price;
    }
}
public class ObjectTest  {
    public static void main(String args[]) {
        TV changhong = new TV();
        changhong.setName("长虹电视");
        changhong.setPrice(5678);
        File file = new File("C:\\Users\\Lenovo\\Desktop\\televisoion.txt");
        try {
            //写入外部文件
            FileOutputStream fileOut=new FileOutputStream(file);
            ObjectOutputStream objectOut = new ObjectOutputStream(fileOut);
            objectOut.writeObject(changhong);
            objectOut.close();

            //外部文件读出
            FileInputStream fileIn=new FileInputStream(file);
            ObjectInputStream objectIn=new ObjectInputStream(fileIn);
            TV xinfei= (TV) objectIn.readObject();
            objectIn.close();
           // xinfei.setName("欣菲电视");
            //xinfei.setPrice(6666);

            System.out.println("changhong的名字是"+changhong.getName());
            System.out.println("changhong的价格是"+changhong.getPrice());
            System.out.println("xinfei的名字是"+xinfei.getName());
            System.out.println("xinfei的价格是"+xinfei.getPrice());

        }
        catch(ClassNotFoundException e ){
            System.out.println("读不出对象");
        }
        catch( IOException e){
            System.out.println(e);
        }
    }
}

在这里插入图片描述
在这里插入图片描述
序列化后存储到文件内容:
在这里插入图片描述

====================================================

首先第一个问题,实现序列化的两个原因:
1、将对象的状态保存在存储媒体中以便可以在以后重新创建出完全相同的副本;
2、按值将对象从一个应用程序域发送至另一个应用程序域。

实现serializabel接口的作用是就是可以把对象存到字节流,然后可以恢复,所以你想如果你的对象没实现序列化怎么才能进行持久化和网络传输呢,要持久化和网络传输就得转为字节流,所以在分布式应用中及设计数据持久化的场景中,你就得实现序列化。

第二个问题,是不是每个实体bean都要实现序列化,答案其实还要回归到第一个问题,那就是你的bean是否需要持久化存储媒体中以及是否需要传输给另一个应用,没有的话就不需要,例如我们利用fastjson将实体类转化成json字符串时,并不涉及到转化为字节流,所以其实跟序列化没有关系。

第三个问题,有的时候并没有实现序列化,依然可以持久化到数据库。这个其实我们可以看看实体类中常用的数据类型,例如Date、String等等,它们已经实现了序列化,而一些基本类型,数据库里面有与之对应的数据结构,从我们的类声明来看,我们没有实现serializabel接口,其实是在声明的各个不同变量的时候,由具体的数据类型帮助我们实现了序列化操作。

另外需要注意的是,在NoSql数据库中,并没有与我们java基本类型对应的数据结构,所以在往nosql数据库中存储时,我们就必须将对象进行序列化,同时在网络传输中我们要注意到两个应用中javabean的serialVersionUID要保持一致,不然就不能正常的进行反序列化。
  解释来自https://www.cnblogs.com/hhhshct/p/9664390.html

发布了156 篇原创文章 · 获赞 16 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_44001521/article/details/104157519
今日推荐