`
febird
  • 浏览: 254270 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

febird.dataio vs boost.serialization 运行性能对比

阅读更多

代码表示的是数据格式,DATA_IO_LOAD_SAVE 在 <febird/io/DataIO.h> 中定义

对boost,DATA_IO_LOAD_SAVE 的定义相当于:

#define DATA_IO_LOAD_SAVE(Class, Members) \

    friend class boost::serialization::access; \

    template<class Archive> \

    void serialize(Archive & ar, const unsigned int version) \

    { ar Members; }

 

数据格式:

 

struct MyData1

{

    uint32_t a, b, c;

    uint32_t d[5];

    DATA_IO_LOAD_SAVE(MyData1, &a&b&c&d)

};

 

struct MyData2

{

    uint32_t a, b, c, d;

    MyData1 e;

DATA_IO_LOAD_SAVE(MyData2, &a&b&c&d&e)

};

 

struct MyData3

{

    uint32_t a, b, c;

    uint32_t d;

};

DATA_IO_DUMP_RAW_MEM(MyData3)

 

struct VarIntD

{

    var_uint32_t a, b, c, d, e, f;

 

    VarIntD()

    {

        a = 127;

        b = 128;

        c = 128*128;

        d = 128*128*128;

        e = 128*128*128*128;

        f = 1;

    }

    DATA_IO_LOAD_SAVE(VarIntD, &a&b&c&d&e&f)

};

typedef pair<MyData2, MyData3> MyData23; 

 

boost_bin_save: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[   1004,    1004,    1.0000]
    vector<MyData1>       .size= 4000, time[  23918,   23918,    1.0000]
    vector<string>        .size= 4000, time[   9266,    9266,    1.0000]
    map<int,string>       .size= 3756, time[  19434,   19434,    1.0000]
    loop{MyData1 },  loop count= 4000, time[  23592,   23592,    1.0000]
    loop{VarIntD },  loop count= 4000, time[  52832,   52832,    1.0000]
    vector<MyData23>,     .size= 4000, time[  68581,   68581,    1.0000]

boost_bin_load: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    766,     766,    1.0000]
    vector<MyData1>       .size= 4000, time[  26738,   26738,    1.0000]
    vector<string>        .size= 4000, time[  41097,   41097,    1.0000]
    map<int,string>       .size= 3756, time[  63985,   63985,    1.0000]
    loop{MyData1 },  loop count= 4000, time[  23486,   23486,    1.0000]
    loop{VarIntD },  loop count= 4000, time[  88218,   88218,    1.0000]
    vector<MyData23>,     .size= 4000, time[  75386,   75386,    1.0000]

File Save Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    593,    1004,    1.6910]
    vector<MyData1>       .size= 4000, time[   1043,   23918,   22.9288]
    vector<string>        .size= 4000, time[   3741,    9266,    2.4767]
    map<int,string>       .size= 3756, time[   5018,   19434,    3.8723]
    loop{MyData1 },  loop count= 4000, time[   2898,   23592,    8.1390]
    loop{VarIntD },  loop count= 4000, time[   8664,   52832,    6.0977]
    vector<MyData23>,     .size= 4000, time[   5768,   68581,   11.8887]

File Load Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    400,     766,    1.9156]
    vector<MyData1>       .size= 4000, time[    868,   26738,   30.7855]
    vector<string>        .size= 4000, time[   3812,   41097,   10.7790]
    map<int,string>       .size= 3756, time[  58671,   63985,    1.0906]
    loop{MyData1 },  loop count= 4000, time[   1547,   23486,   15.1780]
    loop{VarIntD },  loop count= 4000, time[   2580,   88218,   34.1866]
    vector<MyData23>,     .size= 4000, time[   4667,   75386,   16.1499]

File Save Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[   1114,    1004,    0.9010]
    vector<MyData1>       .size= 4000, time[   4044,   23918,    5.9143]
    vector<string>        .size= 4000, time[   3480,    9266,    2.6628]
    map<int,string>       .size= 3756, time[   5089,   19434,    3.8185]
    loop{MyData1 },  loop count= 4000, time[   3622,   23592,    6.5132]
    loop{VarIntD },  loop count= 4000, time[   7255,   52832,    7.2812]
    vector<MyData23>,     .size= 4000, time[   6831,   68581,   10.0397]

File Load Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    500,     766,    1.5318]
    vector<MyData1>       .size= 4000, time[   1543,   26738,   17.3266]
    vector<string>        .size= 4000, time[   3924,   41097,   10.4728]
    map<int,string>       .size= 3756, time[  58689,   63985,    1.0902]
    loop{MyData1 },  loop count= 4000, time[   2957,   23486,    7.9425]
    loop{VarIntD },  loop count= 4000, time[   2575,   88218,   34.2497]
    vector<MyData23>,     .size= 4000, time[   5375,   75386,   14.0246]

Memory Save Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    198,    1004,    5.0705]
    vector<MyData1>       .size= 4000, time[    510,   23918,   46.8615]
    vector<string>        .size= 4000, time[   3088,    9266,    2.9999]
    map<int,string>       .size= 3756, time[   3679,   19434,    5.2817]
    loop{MyData1 },  loop count= 4000, time[   1106,   23592,   21.3311]
    loop{VarIntD },  loop count= 4000, time[   7546,   52832,    7.0006]
    vector<MyData23>,     .size= 4000, time[   2242,   68581,   30.5868]

Memory Load Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    170,     766,    4.4853]
    vector<MyData1>       .size= 4000, time[    505,   26738,   52.9088]
    vector<string>        .size= 4000, time[   3134,   41097,   13.1104]
    map<int,string>       .size= 3756, time[  58097,   63985,    1.1013]
    loop{MyData1 },  loop count= 4000, time[    114,   23486,  205.5526]
    loop{VarIntD },  loop count= 4000, time[   4586,   88218,   19.2339]
    vector<MyData23>,     .size= 4000, time[   1894,   75386,   39.7889]

Memory Save Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    557,    1004,    1.8029]
    vector<MyData1>       .size= 4000, time[   2392,   23918,    9.9960]
    vector<string>        .size= 4000, time[   2916,    9266,    3.1778]
    map<int,string>       .size= 3756, time[   3563,   19434,    5.4539]
    loop{MyData1 },  loop count= 4000, time[   2203,   23592,   10.7061]
    loop{VarIntD },  loop count= 4000, time[   7307,   52832,    7.2294]
    vector<MyData23>,     .size= 4000, time[   3742,   68581,   18.3243]

Memory Load Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    301,     766,    2.5464]
    vector<MyData1>       .size= 4000, time[   1182,   26738,   22.6056]
    vector<string>        .size= 4000, time[   3150,   41097,   13.0453]
    map<int,string>       .size= 3756, time[  57657,   63985,    1.1098]
    loop{MyData1 },  loop count= 4000, time[   1549,   23486,   15.1589]
    loop{VarIntD },  loop count= 4000, time[   4610,   88218,   19.1325]
    vector<MyData23>,     .size= 4000, time[   2650,   75386,   28.4410]

Uncheck Save Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    173,    1004,    5.7797]
    vector<MyData1>       .size= 4000, time[    480,   23918,   49.8057]
    vector<string>        .size= 4000, time[   2480,    9266,    3.7358]
    map<int,string>       .size= 3756, time[   3436,   19434,    5.6552]
    loop{MyData1 },  loop count= 4000, time[   1070,   23592,   22.0381]
    loop{VarIntD },  loop count= 4000, time[   7110,   52832,    7.4300]
    vector<MyData23>,     .size= 4000, time[   2155,   68581,   31.8240]

Uncheck Load Native: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    172,     766,    4.4489]
    vector<MyData1>       .size= 4000, time[    530,   26738,   50.3747]
    vector<string>        .size= 4000, time[   2985,   41097,   13.7681]
    map<int,string>       .size= 3756, time[  57228,   63985,    1.1181]
    loop{MyData1 },  loop count= 4000, time[     17,   23486, 1355.9839]
    loop{VarIntD },  loop count= 4000, time[   2472,   88218,   35.6816]
    vector<MyData23>,     .size= 4000, time[   1838,   75386,   40.9979]

Uncheck Save Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    518,    1004,    1.9359]
    vector<MyData1>       .size= 4000, time[   2415,   23918,    9.9001]
    vector<string>        .size= 4000, time[   2430,    9266,    3.8126]
    map<int,string>       .size= 3756, time[   3599,   19434,    5.3985]
    loop{MyData1 },  loop count= 4000, time[   2037,   23592,   11.5812]
    loop{VarIntD },  loop count= 4000, time[   7476,   52832,    7.0660]
    vector<MyData23>,     .size= 4000, time[   3740,   68581,   18.3325]

Uncheck Load Portable: loop=10, time[febird, boost, ratio=b/f] in us
    vector<pair<int,int> >.size= 4000, time[    281,     766,    2.7232]
    vector<MyData1>       .size= 4000, time[   1199,   26738,   22.2897]
    vector<string>        .size= 4000, time[   2731,   41097,   15.0437]
    map<int,string>       .size= 3756, time[  57136,   63985,    1.1199]
    loop{MyData1 },  loop count= 4000, time[   1578,   23486,   14.8825]
    loop{VarIntD },  loop count= 4000, time[   2628,   88218,   33.5581]
    vector<MyData23>,     .size= 4000, time[   2420,   75386,   31.1459]

 

项目地址:http://code.google.com/p/febird

分享到:
评论

相关推荐

    febird C++ 库(附带所有源码)

    febird implemented a serialization framework(vs boost.serialization/google.protocolbuffer), can be used in protocol parsing, big/small data serialization, even in very small object serialize, ...

    rpc-Remote Procedure Call源码2

    远程过程调用(RPC,Remote Procedure Call)是分布式计算领域中的一个重要概念,它允许一个程序在不理解...同时,这也是一个很好的实践机会,让我们能够亲手编写和运行一个简单的RPC应用,从而加深对RPC机制的理解。

    Font Awesome图标字体库提供可缩放矢量图标,它可以被定制大小、颜色、阴影以及任何可以用CSS的样式

    Font Awesome图标字体库提供可缩放矢量图标,它可以被定制大小、颜色、阴影以及任何可以用CSS的样式

    EDAfloorplanning

    介绍了physical design的floorplanning问题

    数学建模培训资料 数学建模实战题目真题答案解析解题过程&论文报告 最低生活保障问题的探索 共20页.pdf

    数学建模培训资料 数学建模实战题目真题答案解析解题过程&论文报告 最低生活保障问题的探索 共20页.pdf

    变更用水性质定额申请表.xls

    变更用水性质定额申请表.xls

    GitHub Desktop版快速下载

    从官网上下载下来,作为资源存储,方便安装,此资源为windows版本

    嗨玩旅游网站-JAVA-基于springboot嗨玩旅游网站设计与实现(毕业论文+PPT)

    嗨玩旅游网站-JAVA-基于springboot嗨玩旅游网站设计与实现(毕业论文+PPT)

    本科毕业设计 基于Python中国知网(cnki)爬虫及数据可视化详细文档+全部资料.zip

    【资源说明】 本科毕业设计 基于Python中国知网(cnki)爬虫及数据可视化详细文档+全部资料.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    三菱plc基于mx组件的通用访问远程api接口

    api代码

    基于 Java 实现的24点卡牌游戏课程设计

    【作品名称】:基于 Java 实现的24点卡牌游戏【课程设计】 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: Java小游戏--24点卡牌游戏 将扑克牌(除大小王)随机打乱,每次出现4张卡牌,每张卡牌使用一次,13个回合。 A代表1,J代表11,Q代表12,K代表13。 可2-4人局域网同时在线对战,100秒倒计时结束前回答正确可获得积分,先回答的可获4分,后回答的分数依次递减。 实时显示玩家排名。 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。

    用 Python 实现的可扩展布隆过滤器.zip

    用 Python 实现的可扩展布隆过滤器皮布卢姆pybloom是一个包含 Bloom Filter 数据结构以及可扩展 Bloom Filter 实现的模块,如下所述P. Almeida、C.Baquero、N. Preguiça、D. Hutchison,可扩展布隆过滤器,(GLOBECOM 2007),IEEE,2007。如果您了解需要提前留出多少位来存储整个集合,那么布隆过滤器就是您的不二之选。可扩展布隆过滤器允许您的布隆过滤器位根据误报概率和大小进行增长。当过滤器达到容量上限时,即为“满”M * ((ln 2 ^ 2) / abs(ln p)),其中 M 是位数,p 是误报概率。当达到容量上限时,将创建一个比上一个过滤器大得多的新过滤器,其误报概率更小,哈希函数数量更多。>>> from pybloom import BloomFilter>>> f = BloomFilter(capacity=1000, error_rate=0.001)>>> [f.add(x) for x in range(10)][False, False, False,

    计算机学院宿舍美化大赛.rar

    计算机学院宿舍美化大赛.rar

    基于java的运动器械购物商城设计与实现.docx

    基于java的运动器械购物商城设计与实现.docx

    基于PBL-CDIO的材料成型及控制工程课程设计实践与改革

    内容概要:文章介绍了针对“卓越工程师教育培养计划”,结合PBL和CDIO工程教育理念,对材料成型及控制工程专业课程设计的实践教学改革进行探索。首先在命题设计上依托企业实践项目,确保设计内容与生产实际紧密结合,具有较强的创新性和实用性。在过程管理中,采用分组合作和面向实际问题导向的教学方法,提升学生的工程素养和创新思维。通过课程设计的成绩考核,结合校内外导师的共同评价,客观全面衡量学生的学习成果。指导教师发挥了组织、支持和引导等多方面的角色作用。 适合人群:高等院校材料成型及控制工程专业学生和教学管理人员;工程教育领域的研究人员。 使用场景及目标:旨在提升工科学生的工程实践能力和创新能力,使其具备解决复杂实际工程问题的能力。通过改革教学内容和方法,改善传统课程设计中存在的不足,培养出高素质的技术人才。 其他说明:改革措施在实际运行中取得了较好的教学效果,提高了学生的就业竞争力,但仍存在一些不足之处需要在未来进行完善。

    设计模式学习.zip

    设计模式学习

    C的两数相加求和的程序代码

    C的两数相加求和的程序代码

    Viper是一个基于Anno微服务引擎开发的Dashboard示例项目。Anno底层通讯采用grpc、thrift.zip

    Viper是一个基于Anno微服务引擎开发的Dashboard示例项目。Anno底层通讯采用grpc、thrift

    本教程播放列表涵盖了 Python 中的数据结构和算法 每个教程都有数据结构或算法背后的理论、BIG O 复杂性分析和可供练习的练习 .zip

    本教程播放列表涵盖了 Python 中的数据结构和算法。每个教程都有数据结构或算法背后的理论、BIG O 复杂性分析和可供练习的练习。使用 Python 的数据结构和算法本教程涵盖了 Python 中的数据结构和算法。每个教程都包含数据结构或算法背后的理论、BIG O 复杂度分析以及可供练习的练习。要观看视频,您可以访问播放列表https://www.youtube.com/playlist?list=PLeo1K3hjS3uu_n_a__MI_KktGTLYopZ12订阅 codebasics youtube 频道https://www.youtube.com/c/codebasics

    python入门-安装Python软件包.pdf

    python入门——安装Python软件包

Global site tag (gtag.js) - Google Analytics