对象存储

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了对象存储相关的知识,希望对你有一定的参考价值。

对象 有状态和行为两种属性,行为存在于类中,而状态存在于单独的对象中。

让对象可以被序列化,类必须要实现Serializable:

     Serializable接口被称为marker或tag类的标记用接口,因为此接口没有任何方法需要实现的。他的唯一目的就是声明实现它的类,可以被序列化的。

  如果某个实例变量不能或不应该被序列化,就把他标记为transient(瞬时)的。

  例:

  class Chat implements Serializable{

    transient String currentid;

              String usename; 

  }

一:将序列化对象写入文件

  1:创建FileOutputStream

    FileOutputStream fs = new FileOutputStream("store.ser");//如果文件不存在 他会被自动创建

  2:创建ObjectOutputStream

    ObjectOutputStream os = new ObjectOutputStream(fs);

  3:写入对象

    os.writeObject();

  4:关闭对象流

    os.writeObject(new Object());//写入实例化的对象

  对象被序列化发生了什么:

      堆上的对象有状态-实例变量的值,这些值让同一个类的不同实例有不同的意义。

      序列化的对象保存了实例变量的值,因此之后可以在堆上带回一模一样的实例。

  技术分享

二:解序列化(Deserialization):还原对象

  FileInputStream fs = new FileInputStream  = new FileInputStream("store".ser);

    ObjectInputStream os = new ObjectInputSream(fs);

    Object one = os.readObject();

  Object two = os.readObject();

  os.close();

 技术分享

 技术分享

 

 

 技术分享

 

以上是关于对象存储的主要内容,如果未能解决你的问题,请参考以下文章

移动云对象存储EOS能干啥呀?

存储服务分类:块存储、文件存储、对象存储

redis存储对象大小2m

【ceph】对象存储 - bucket命名规范

对象存储是什么?EasyCVR新增对象存储功能及实现方法

块存储、文件存储、对象存储这三者的本质差别是啥?