1// Copyright (C) 2011 Tim Blechmann
2//
3// Distributed under the Boost Software License, Version 1.0. (See
4// accompanying file LICENSE_1_0.txt or copy at
5// http://www.boost.org/LICENSE_1_0.txt)
6
7#include <cstdlib> //std::system
8#include <sstream>
9
10#include <boost/interprocess/managed_shared_memory.hpp>
11#include <boost/lockfree/queue.hpp>
12#include <boost/thread/thread.hpp>
13
14using namespace boost::interprocess;
15typedef allocator<int, managed_shared_memory::segment_manager> ShmemAllocator;
16typedef boost::lockfree::queue<int,
17 boost::lockfree::allocator<ShmemAllocator>,
18 boost::lockfree::capacity<2048>
19 > queue;
20
21int main (int argc, char *argv[])
22{
23 if(argc == 1){
24 struct shm_remove
25 {
26 shm_remove() { shared_memory_object::remove(filename: "boost_queue_interprocess_test_shm"); }
27 ~shm_remove(){ shared_memory_object::remove(filename: "boost_queue_interprocess_test_shm"); }
28 } remover;
29
30 managed_shared_memory segment(create_only, "boost_queue_interprocess_test_shm", 262144);
31 ShmemAllocator alloc_inst (segment.get_segment_manager());
32
33 queue * q = segment.construct<queue>(name: "queue")(alloc_inst);
34 for (int i = 0; i != 1024; ++i)
35 q->push(t: i);
36
37 std::string s(argv[0]); s += " child ";
38 if(0 != std::system(command: s.c_str()))
39 return 1;
40
41 while (!q->empty())
42 boost::thread::yield();
43 return 0;
44 } else {
45 managed_shared_memory segment(open_only, "boost_queue_interprocess_test_shm");
46 queue * q = segment.find<queue>(name: "queue").first;
47
48 int from_queue;
49 for (int i = 0; i != 1024; ++i) {
50 bool success = q->pop(ret&: from_queue);
51 assert (success);
52 assert (from_queue == i);
53 }
54 segment.destroy<queue>(name: "queue");
55 }
56 return 0;
57}
58

source code of boost/libs/lockfree/test/queue_interprocess_test.cpp