C++序列化使用
error C2248 无法访问私有成员 :原因 ifstream 作为参数必须传引用!
(1):C++使用STL序列化:原文链接:http://blog.csdn.net/pandaxcl/article/details/649682
在用C++编写应用程序的过程中,经常涉及到序列化的问题,但是序列化的问题通常都
会有非常繁琐的过程代码需要书写,本文中就是通过简单的步骤实现了程序的序列化问题
,简单直接,和其它的序列化方案有着很大的不同。 首先来看看简单的数据写入文件和从文件读入数据的代码: 特别注解:本人特别喜欢用STL来书写代码,一方面是便于移植,但是另一方却是在于
用STL书写的代码简单直接,可读性好。如果还不熟悉STL,本文则不大适合你:)
#endif
#if CODE1
////////////////////////////////////////////////////////////////////////////////
//模拟程序序列化的简单代码
#include <iostream>//cout
#include <fstream>//ofstream,ifstream
#include <vector>//vector
#include <iterator>//ostream_iterator,istream_iterator,back_inserter
#include <numeric>//partial_sum
#include <algorithm>//copy
#include <string>
#include <sstream>
using namespace std;//简化代码的书写,经std名字空间成为默认名字空间
int main()
{
{//从程序序列化到文件
vector<int> v(5,1);//[1,1,1,1,1]
partial_sum(v.begin(),v.end(),v.begin());//[1,2,3,4,5]
ofstream out("data.txt");//生成文件输出流
//将数组v中的数据全部输出到文件流中,这种操作在C++中成为文件操作
//在这里暂时称为序列化到文件操作。实际上这里为了简单序列化的格式
//为文本文件格式。如果需要其它的格式完全可以通过自定义输出流游标
//的方式,或者重载运算符operator<<和operator>>实现不同的序列化格
//式。可以参见本人的其它相关文档。
copy(v.begin(),v.end(),ostream_iterator<int>(out," "));
}
{//从文件序列化到程序
vector<int> v;//模拟应用程序中数据
ifstream in("data.txt");//建立输入流
//下面的这行代码从文件中提取数据到v中,模拟了应用程序的序列化过程
copy(istream_iterator<int>(in),istream_iterator<int>(),back_inserter(v));
//下面的这行代码仅仅只是为了显示是否真的被序列化到了程序中
copy(v.begin(),v.end(),ostream_iterator<int>(cout," "));
}
return 0;
}
////////////////////////////////////////////////////////////////////////////////
//该程序的输出如下:
/*******************************************************************************
1 2 3 4 5
*******************************************************************************/
//data.txt中的内容如下:
/*******************************************************************************
1 2 3 4 5
*******************************************************************************/
////////////////////////////////////////////////////////////////////////////////
#endif//CODE1
(2):第二种方式:使用POST++ 类库
信息科技第一门户:
原文链接:http://www.atcto.net/Tech/C/2012-10-10/C,12101014524800000002.html
C++精彩博客系列:http://blog.chinaunix.net/topic/Cjishu/
(3) Boost.Serialization
链接介绍:http://zh.highscore.de/cpp/boost/serialization.html
轻量序列化介绍:http://blog.csdn.net/fhxpp_27/article/details/8556948
Boost.Serialization可以创建或重建程序中的等效结构,并保存为二进制数据、文本数据、XML或者有用户自定义的其他文件。该库具有以下吸引人的特性:
- 代码可移植(实现仅依赖于ANSI C++)。
- 深度指针保存与恢复。
- 可以序列化STL容器和其他常用模版库。
- 数据可移植。
- 非入侵性。
原文链接:http://www.cnblogs.com/lanxuezaipiao/p/3703988.html
(4):使用MessagePack进行序列化
原文链接:http://www.tuicool.com/articles/qMrayai
msgpack官方主页:http://msgpack.org/
github主页:https://github.com/msgpack/msgpack
序列化自定义类型:msgpack已支持了很多的标准类型,但有时我们会自己定义新的类型,这时,我们必须对新类型做某些修改,以使msgpack可以操作它。
另外,如果你的类型中含有低层指针,则还需要进行一些处理,否则,msgpack只会进行浅拷贝,无法序列化指针所指向的内存数据。
假设我们原本的类型如下:
struct Foo
{
int i;
string str;
char* data;
};
那么要让msgpack操作它,应修改为如下结构:
struct Foo
{
int i;
string str;
// 原始指针类型,内部封装了pack_raw和pack_raw_body方法
msgpack::type::raw_ref data; MSGPACK_DEFINE(i, str, data);
}; 1 /*
2 * msgpack C++试验:序列化/反序列化自定义数据结构.
3 * Author: 赵子清
4 * Blog: http://www.cnblogs.com/zzqcn
5 * */
6
7
8 #include <msgpack.hpp>
9 #include <string>
10 #include <cstring>
11 #include <iostream>
12 using namespace std;
13
14
15 struct Foo
16 {
17 int i;
18 string str;
19 // 原始指针类型,内部封装了pack_raw和pack_raw_body方法
20 msgpack::type::raw_ref data;
21
22 MSGPACK_DEFINE(i, str, data);
23 };
24
25
26 int main(int argc, char** argv)
27 {
28 Foo f;
29 f.i = 4;
30 f.str = "hello world";
31 const char* tmp = "msgpack";
32 f.data.ptr = tmp;
33 f.data.size = strlen(tmp) + 1;
34
35 msgpack::sbuffer sbuf;
36 msgpack::pack(sbuf, f);
37
38 msgpack::unpacked unpack;
39 msgpack::unpack(&unpack, sbuf.data(), sbuf.size());
40
41 msgpack::object obj = unpack.get();
42
43 Foo f2;
44 obj.convert(&f2);
45
46 cout << f2.i << ", " << f2.str << ", ";
47 cout << f2.data.ptr << endl;
48
49 return 0;
50 }
输出结果:
4, hello world, msgpack
(5):自己编写序列化代码
由于C++库的开放性差,弹性小,不能用于自己的结构体map,最后还是自己专门为自己的结构体写了序列化代码
C++序列化使用的更多相关文章
- 【.net 深呼吸】序列化中的“引用保留”
假设 K 类中有两个属性/字段的类型相同,并且它们引用的是同一个对象实例,在序列化的默认处理中,会为每个引用单独生成数据. 看看下面两个类. [DataContract] public class 帅 ...
- 【.net 深呼吸】设置序列化中的最大数据量
欢迎收看本期的<老周吹牛>节目,由于剧组严重缺钱,故本节目无视频无声音.好,先看下面一个类声明. [DataContract] public class DemoObject { [Dat ...
- 用dubbo时遇到的一个序列化的坑
首先,这是标题党,问题并不是出现在序列化上,这是报错的一部分: Caused by: com.alibaba.dubbo.remoting.RemotingException: Failed to s ...
- Unity 序列化
Script Serialization http://docs.unity3d.com/Manual/script-Serialization.html 自定义序列化及例子: http://docs ...
- Unity 序列化 总结
查找了 Script Serialization http://docs.unity3d.com/Manual/script-Serialization.html 自定义序列化及例子: http:// ...
- [C#] C# 知识回顾 - 序列化
C# 知识回顾 - 序列化 [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902005.html 目录 序列化的含义 通过序列化保存对象数据 众 ...
- Newtonsoft.Json设置类的属性不序列化
参考页面: http://www.yuanjiaocheng.net/webapi/parameter-binding.html http://www.yuanjiaocheng.net/webapi ...
- C# 序列化与反序列化几种格式的转换
这里介绍了几种方式之间的序列化与反序列化之间的转换 首先介绍的如何序列化,将object对象序列化常见的两种方式即string和xml对象; 第一种将object转换为string对象,这种比较简单没 ...
- Netty实现高性能RPC服务器优化篇之消息序列化
在本人写的前一篇文章中,谈及有关如何利用Netty开发实现,高性能RPC服务器的一些设计思路.设计原理,以及具体的实现方案(具体参见:谈谈如何使用Netty开发实现高性能的RPC服务器).在文章的最后 ...
- .Net深入实战系列—JSON序列化那点事儿
序 当前主流的序列化JSON字符串主要有两种方式:JavaScriptSerializer及Json.net(Nuget标识:Newtonsoft.Json).JavaScriptSerializer ...
随机推荐
- 宏、预编译(day12)
指针数组里的每个存储区是一个指针类型 的存储区 字符指针数组里包含多个字符类型指针,其中 每个指针可以表示一个字符串 字符指针数组可以用来表示多个相关字符串 主函数的第二个参数是一个字符指针数组, 其 ...
- javascript/jquery获取地址栏url参数的方法
1.jquery获取url window.location.href; 2.通过javascript是如何获取url中的某个参数 function getUrlParam(name) { var re ...
- 利用python暴力破解压缩文件密码
import randomimport sysimport zipfileimport timefrom threading import Threadfrom multiprocessing imp ...
- (转载)关于初学者上传文件到github的方法
说来也惭愧,我是最近开始用github,小白一个,昨天研究了一个下午.终于可以上传了,所以今天写点,一来分享是自己的一些经验,二来也是做个记录,万一哪天又不记得了:) 废话不多说,直接来,这次主要介绍 ...
- ACDream - Power Sum
先上题目: Power Sum Time Limit: 20000/10000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) S ...
- 【ACM】hdu_zs3_1005_String Matching_201308100920
String Matching Time Limit : 2000/1000ms (Java/Other) Memory Limit : 20000/10000K (Java/Other)Tota ...
- VS的代码管理工具
参考文章 可以从中知道修改代码段是要打开相关路径下的文档来修改 官方下载地址 百度云盘 如果项目中国有一些代码重复率非常高,可以把这些代码做成snippet代码段,简化成快捷键命令,加速开发
- UVa 12525 Boxes and Stones (dp 博弈)
Boxes and Stones Paul and Carole like to play a game with S stones and B boxes numbered from 1 to B. ...
- 【cl】eclipse配置svn
查看Eclipse版本号 http://jingyan.baidu.com/article/020278118660e81bcd9ce545.html Window>preferences输入S ...
- luogu1967 货车运输 最大瓶颈生成树
题目大意 给出一张图,给出q对点,求这两个点间权值最小边最大的路径,输出这个最小边权. 题解 我们先一条一条边建图.当建立的边使得图中形成环时,因为环中的每个节点只考虑是否连通和瓶颈大小,要想互相连通 ...