对象的序列化

1、概念

  序列化对象 -将对象的类的信息以及对象的成员变量以二进制流的方式依次写入到文件的过程。

  反序列化对象 -从文件中读取类的信息创建对象,然后读取成员变量赋值给新建的对象的过程。

2、定义支持序列化的类

  2.1派生自CObject类

  2.2在类内添加序列化的声明宏

    DECLARE_SERIAL(class_name)

      class_name:要成为序列化类的类名

  2.3在类外添加序列化的实现宏

    IMPLEMENT_SERIAL(class_name, base_class_name, wSchema)

      class_name:类名称

      base_class_name:基类的名称

      wSchema:版本号

  2.4重写CObject::Serialize()函数,在函数中完成成员变量的序列化

3、使用

  在读写对象时,参数是对象的指针。

时间: 2024-10-22 20:43:44

对象的序列化的相关文章

对象的序列化与反序列化-serialize与unserialize

通俗的来说: 对象的序列化的基本概念: 所谓对象的序列化,就是可以把某个对象的属性名称,属性值, 属性类型,类名 以字符串的形式保存到文件中,在你需要的时候可以重新恢复. 对象的反序列化的基本概念, 是序列化的逆向过程. 函数: 序列化:serialize() string serialize ( mixed $value ) 手册上给的定义是:产生一个可存储的值的表示 其实就是在不丢失对象的结构和类型的情况下将一个对象转换成一个字符串,可以存储在任何地方 在 PHP 3 中,对象属性将被序列化

asp.net中对象的序列化,方便网络传输

对象序列化 是将对象状态转换为可保持或传输的格式的过程.反序列化 是将流转换为对象序列化和反序列化相结合 可以使对象数据轻松的存储和传递 在 .NET 中,如果是对象可序列化,需要在 声明对象的开始部分加上 [Serializable] 这个属性,并且不能被继承如一个类 [Serializable]public class A{    public string title;} public class B : A{    public int total;} 则 对象B 不可被序列化 在 .N

Qt持久性对象进行序列化(同时比较了MFC与Java的方法)

Mfc和Java中自定义类的对象都可以对其进行持久性保存,Qt持久性对象进行序列化当然也是必不可少的.不过这个问题还真困扰了我很长时间……Mfc通过重写虚函数Serialize().Java则是所属的类必须实现java.io.Serializable或Externalizable接口完成.Qt是怎么搞定这个事情那,QDataStream类:让我们不禁想起Mfc中的CAchive类.Java中的java.io.ObjectOutputStream/ObjectInputStream类,分别提供了对

Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

Java实现对象的序列化

什么是对象的序列化? 序列化:把对象转化成字节序列的过程就是对象的序列化:反序列化:把字节序列转化成对象的过程就是对象的反序列化.单看概念比较抽象,但是看代码就会明白. 对象序列化的用途 1.Java程序在运行中,对象都是分配在内存中,而序列化的一个用途就是将内存的中对象转化成磁盘中的对象. 2.对象不能直接在网络中传输,有时候需要将对象转成字节序列在网络中传输,这就是对象序列化的第二个用途. 如何实现对象的序列化? 1.新建一个实体对象,实现Serializable接口,这个实体对象就可以进行

Java对象的序列化

1.概念 序列化:把Java对象转换为字节序列的过程. 反序列化:把字节序列恢复为Java对象的过程. 2.用途 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 3.对象序列化 3.1序列化API java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中.只有实现了Serial

对象的序列化以及反序列

一:需求分析 在实际的B/S结构中,对象的序列化和反序列化很重要,尤其是请求量比较大的情况,服务器压力很大, 会把一部分session序列化,然后保存到硬盘中. 二:定义DTO对象 定义的实体类一定要实现 Serializable接口,才可以序列化. 1 /** 2 * 3 */ 4 package com.hlcui.dto; 5 6 import java.io.Serializable; 7 8 /** 9 * @author Administrator 学生实体类 10 */ 11 pu

对象的序列化(串行化)分析(一)

对象的序列化(串行化)序列化概念:(1)对象的寿命通常随着生成该对象的程序的终止而终止.有时候,可能需要将对象的状态保存下 来,在需要时再将对象恢复.我们把对象的这种能记录自己的状态以便将来再生的能力.叫作对象的持续性(persistence).对象通过写出描述自己状 态的数值来记录自己 ,这个过程叫对象的串行化(Serialization-连续) .(2)一个对象随着创建而存在,随着程序结束而结束.那 如果我要保存一个对象的状态呢?Java序列化能够将对象的状态写入byte流存储起来,也从其他

Java对象的序列化和反序列化(转)

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

访问修饰限定符的简单总结、final/abstruct/interface对类的限制、自动加载机制、序列化与反序列化【数据持久化和对象的序列化问题】、对象的拷贝(按引用是因为对象标识)和克隆(__clone方法中的this指向)

1.针对访问修饰限定符的理解只需要两点:(1)针对的是类的概念和访问代码的位置来确定是否能够访问(2)对访问修饰限定符的使用时只需要对该成员的使用场景注意即可[也就是内部,继承类,外部进行访问的权限] 不需要对内部进行太多理解[需要对php底层理解时进行理解] [重点][用途]通过访问修饰限定符将内部成员的权限合理的限制,然后再使用公共接口来调用这个基本服务,保证外部不能访问其内部的构件[这样既能够通过类内的设置,将内部的功能实现更好的限制,只有最外层的接口可以正常被访问到,而不了解内部的业务]