Sha256: d6d669b8b33dc6e27d0b0ff6bc0cfd022f5c7ab9c6db11ce1a251402bd13e457

Contents?: true

Size: 1.86 KB

Versions: 18

Compression:

Stored size: 1.86 KB

Contents

// MessagePack for C++ example
//
// Copyright (C) 2013-2015 KONDO Takatoshi
//
//    Distributed under the Boost Software License, Version 1.0.
//    (See accompanying file LICENSE_1_0.txt or copy at
//    http://www.boost.org/LICENSE_1_0.txt)
//

// g++ -std=c++11 -O3 -g -Ipath_to_msgpack_src -Ipath_to_boost speed_test.cc -Lpath_to_boost_lib -lboost_timer -lboost_system
// export LD_LIBRARY_PATH=path_to_boost_lib

#include <msgpack.hpp>
#include <string>
#include <iostream>
#include <sstream>
#include <map>
#include <boost/timer/timer.hpp>

void test_map_pack_unpack() {
    std::cout << "[TEST][map_pack_unpack]" << std::endl;
    // setup
    std::cout << "Setting up map data..." << std::endl;
    std::map<int, int> m1;
    int const num = 30000000L;
    for (int i = 0; i < num; ++i) m1[i] = i;
    std::cout << "Start packing..." << std::endl;
    std::stringstream buffer;
    {
        boost::timer::cpu_timer timer;
        msgpack::pack(buffer, m1);
        std::string result = timer.format();
        std::cout << result << std::endl;
    }
    std::cout << "Pack finished..." << std::endl;

    buffer.seekg(0);
    std::string str(buffer.str());

    msgpack::object_handle oh;
    std::cout << "Start unpacking...by void unpack(object_handle& oh, const char* data, size_t len)" << std::endl;
    {
        boost::timer::cpu_timer timer;
        msgpack::unpack(oh, str.data(), str.size());
        std::string result = timer.format();
        std::cout << result << std::endl;
    }
    std::cout << "Unpack finished..." << std::endl;
    std::map<int, int> m2;
    std::cout << "Start converting..." << std::endl;
    {
        boost::timer::cpu_timer timer;
        oh.get().convert(m2);
        std::string result = timer.format();
        std::cout << result << std::endl;
    }
    std::cout << "Convert finished..." << std::endl;
}

int main(void)
{
    test_map_pack_unpack();
}

Version data entries

18 entries across 18 versions & 1 rubygems

Version Path
script_core-0.3.2 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.3.0 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.7 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.6 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.5 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.4 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.3 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.2 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.1 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.2.0 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.1.1 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.1.0 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.6 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.5 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.4 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.3 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.2 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp
script_core-0.0.1 ext/enterprise_script_service/msgpack/example/cpp03/speed_test.cpp