File: doc_managed_allocation_command.cpp

package info (click to toggle)
boost1.35 1.35.0-5
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 203,856 kB
  • ctags: 337,867
  • sloc: cpp: 938,683; xml: 56,847; ansic: 41,589; python: 18,999; sh: 11,566; makefile: 664; perl: 494; yacc: 456; asm: 353; csh: 6
file content (89 lines) | stat: -rw-r--r-- 3,323 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
//////////////////////////////////////////////////////////////////////////////
//
// (C) Copyright Ion Gaztanaga 2006-2007. 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 <boost/interprocess/detail/config_begin.hpp>
//[doc_managed_allocation_command
#include <boost/interprocess/managed_shared_memory.hpp>
#include <cassert>

int main()
{
   using namespace boost::interprocess;

   //Managed memory segment that allocates portions of a shared memory
   //segment with the default management algorithm
   shared_memory_object::remove("MyManagedShm");

   try{
      managed_shared_memory managed_shm(create_only, "MyManagedShm", 10000*sizeof(std::size_t));

      //Allocate at least 100 bytes, 1000 bytes if possible
      std::size_t received_size, min_size = 100, preferred_size = 1000;
      std::size_t *ptr = managed_shm.allocation_command<std::size_t>
         (allocate_new, min_size, preferred_size, received_size).first;

      //Received size must be bigger than min_size
      assert(received_size >= min_size);

      //Get free memory
      std::size_t free_memory_after_allocation = managed_shm.get_free_memory();

      //Now write the data
      for(std::size_t i = 0; i < received_size; ++i) ptr[i] = i;

      //Now try to triplicate the buffer. We won't admit an expansion
      //lower to the double of the original buffer.
      //This "should" be successful since no other class is allocating
      //memory from the segment
      std::size_t expanded_size;
      std::pair<std::size_t *, bool> ret = managed_shm.allocation_command
         (expand_fwd, received_size*2, received_size*3, expanded_size, ptr);

      //Check invariants
      assert(ret.second == true);
      assert(ret.first == ptr);
      assert(expanded_size >= received_size*2);

      //Get free memory and compare
      std::size_t free_memory_after_expansion = managed_shm.get_free_memory();
      assert(free_memory_after_expansion < free_memory_after_allocation);

      //Write new values
      for(std::size_t i = received_size; i < expanded_size; ++i)  ptr[i] = i;

      //Try to shrink approximately to min_size, but the new size
      //should be smaller than min_size*2.
      //This "should" be successful since no other class is allocating
      //memory from the segment
      std::size_t shrunk_size;
      ret = managed_shm.allocation_command
         (shrink_in_place, min_size*2, min_size, shrunk_size, ptr);

      //Check invariants
      assert(ret.second == true);
      assert(ret.first == ptr);
      assert(shrunk_size <= min_size*2);
      assert(shrunk_size >= min_size);

      //Get free memory and compare
      std::size_t free_memory_after_shrinking = managed_shm.get_free_memory();
      assert(free_memory_after_shrinking > free_memory_after_expansion);

      //Deallocate the buffer
      managed_shm.deallocate(ptr);
   }
   catch(...){
      shared_memory_object::remove("MyManagedShm");
      throw;
   }
   shared_memory_object::remove("MyManagedShm");
   return 0;
}
//]
#include <boost/interprocess/detail/config_end.hpp>