mirror of
				https://github.com/msgpack/msgpack-c.git
				synced 2025-10-25 10:09:38 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // MessagePack for C++ example
 | |
| //
 | |
| // Copyright (C) 2013-2015 KONDO Takatoshi
 | |
| //
 | |
| //    Licensed under the Apache License, Version 2.0 (the "License");
 | |
| //    you may not use this file except in compliance with the License.
 | |
| //    You may obtain a copy of the License at
 | |
| //
 | |
| //        http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| //    Unless required by applicable law or agreed to in writing, software
 | |
| //    distributed under the License is distributed on an "AS IS" BASIS,
 | |
| //    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| //    See the License for the specific language governing permissions and
 | |
| //    limitations under the License.
 | |
| //
 | |
| 
 | |
| // 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 <vector>
 | |
| #include <boost/timer/timer.hpp>
 | |
| 
 | |
| template <typename T, std::size_t level>
 | |
| struct vecvec {
 | |
|     typedef std::vector<typename vecvec<T, level - 1>::type> type;
 | |
|     static void fill(type& v, std::size_t num_of_elems, T const& val) {
 | |
|         for (int elem = 0; elem < num_of_elems; ++elem) {
 | |
|             typename vecvec<T, level - 1>::type child;
 | |
|             vecvec<T, level - 1>::fill(child, num_of_elems, val);
 | |
|             v.push_back(child);
 | |
|         }
 | |
|     }
 | |
| };
 | |
| 
 | |
| template <typename T>
 | |
| struct vecvec<T, 0> {
 | |
|     typedef std::vector<T> type;
 | |
|     static void fill(type& v, std::size_t num_of_elems, T const& val) {
 | |
|         for (int elem = 0; elem < num_of_elems; ++elem) {
 | |
|             v.push_back(val);
 | |
|         }
 | |
|     }
 | |
| };
 | |
| 
 | |
| void test_array_of_array() {
 | |
|     std::cout << "[TEST][array_of_array]" << std::endl;
 | |
|     // setup
 | |
|     int const depth = 16;
 | |
|     std::cout << "Setting up array data..." << std::endl;
 | |
|     typename vecvec<int, depth>::type v1;
 | |
|     vecvec<int, depth>::fill(v1, 3, 42);
 | |
| 
 | |
|     std::cout << "Start packing..." << std::endl;
 | |
|     std::stringstream buffer;
 | |
|     {
 | |
|         boost::timer::cpu_timer timer;
 | |
|         msgpack::pack(buffer, v1);
 | |
|         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::unpacked unpacked;
 | |
|     std::cout << "Start unpacking...by void unpack(unpacked& result, const char* data, size_t len)" << std::endl;
 | |
|     {
 | |
|         boost::timer::cpu_timer timer;
 | |
|         msgpack::unpack(unpacked, str.data(), str.size());
 | |
|         std::string result = timer.format();
 | |
|         std::cout << result << std::endl;
 | |
|     }
 | |
|     std::cout << "Unpack finished..." << std::endl;
 | |
|     typename vecvec<int, depth>::type v2;
 | |
|     std::cout << "Start converting..." << std::endl;
 | |
|     {
 | |
|         boost::timer::cpu_timer timer;
 | |
|         unpacked.get().convert(&v2);
 | |
|         std::string result = timer.format();
 | |
|         std::cout << result << std::endl;
 | |
|     }
 | |
|     std::cout << "Convert finished..." << std::endl;
 | |
| }
 | |
| 
 | |
| int main(void)
 | |
| {
 | |
|     test_array_of_array();
 | |
| }
 | 
