////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2004-2012. 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) // // See http://www.boost.org/libs/interprocess for documentation. // ////////////////////////////////////////////////////////////////////////////// #include #include #include #include #include #include #include "print_container.hpp" #include "get_process_id_name.hpp" using namespace boost::interprocess; int main () { const int memsize = 65536; std::string process_name; test::get_process_id_name(process_name); const char *const shMemName = process_name.c_str(); BOOST_TRY{ shared_memory_object::remove(shMemName); //Create shared memory managed_shared_memory segment(create_only, shMemName, memsize); //STL compatible allocator object, uses allocate(), deallocate() functions typedef allocator shmem_allocator_int_t; const shmem_allocator_int_t myallocator (segment.get_segment_manager()); const int max = 100; void *array[max]; const char *allocName = "testAllocation"; typedef boost::interprocess::vector MyVect; //---- ALLOC, NAMED_ALLOC, NAMED_NEW TEST ----// { std::size_t i; //Let's allocate some memory for(i = 0; i < max; ++i){ array[std::ptrdiff_t(i)] = segment.allocate(i+1u); } //Deallocate allocated memory for(i = 0; i < max; ++i){ segment.deallocate(array[std::ptrdiff_t(i)]); } bool res; MyVect *shmem_vect; //Construct and find shmem_vect = segment.construct (allocName) (myallocator); res = (shmem_vect == segment.find(allocName).first); if(!res) return 1; //Destroy and check it is not present segment.destroy (allocName); res = (0 == segment.find(allocName).first); if(!res) return 1; //Construct, dump to a file shmem_vect = segment.construct (allocName) (myallocator); if(shmem_vect != segment.find(allocName).first) return 1; //Destroy and check it is not present segment.destroy (allocName); res = (0 == segment.find(allocName).first); if(!res) return 1; } } BOOST_CATCH(...){ shared_memory_object::remove(shMemName); BOOST_RETHROW } BOOST_CATCH_END shared_memory_object::remove(shMemName); return 0; }