C++ 讯息序列化与反序列化

C++ 消息序列化与反序列化

1. 消息序列化

    将具有一定结构的数据转换成可以存取或者可以传输的形式,比如转换成字符流的形式(char *)。通过序列化后,消息可以在系统各逻辑模块或者网络中传输。



2.消息反序列化

    顾名思义,反序列化与序列化的过程相反。例如,将网络中传过来的放在缓冲区的字节流数据(char *)解码成具有一定含义和结构的数据,然后便可以对接出来的数据进行处理。



3.实例 

3.1) 序列化

  struct User

 {       

         unsigned int id_;                   序列化为char *         | 4 个 byte |  4 个 byte|        不定长      |

         unsigned int age_;      ===============>>  |     id_        |    age_      |   nickname_  |  (char* 中的字节数据存放)

        std::string nickname_;                                

 };    

 3.2) 反序列化

    与上面过程相反。     

 

个人同步博客:   http://blog.csdn.net/moxiaomomo/article/details/6647939

1 楼 raojl 2011-07-31  
用google prototype!