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