Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

This is the documentation for an old version of boost. Click here for the latest Boost documentation.
PrevUpHomeNext

Class template basic_managed_xsi_shared_memory

boost::interprocess::basic_managed_xsi_shared_memory

Synopsis

// In header: <boost/interprocess/managed_xsi_shared_memory.hpp>

template<typename CharType, typename AllocationAlgorithm, 
         template< class IndexConfig > class IndexType> 
class basic_managed_xsi_shared_memory {
public:
  // types
  typedef base_t::size_type size_type;

  // construct/copy/destruct
  basic_managed_xsi_shared_memory() noexcept;
  basic_managed_xsi_shared_memory(create_only_t, const xsi_key &, std::size_t, 
                                  const void * = 0, 
                                  const permissions & = permissions());
  basic_managed_xsi_shared_memory(open_or_create_t, const xsi_key &, 
                                  std::size_t, const void * = 0, 
                                  const permissions & = permissions());
  basic_managed_xsi_shared_memory(open_read_only_t, const xsi_key &, 
                                  const void * = 0);
  basic_managed_xsi_shared_memory(open_only_t, const xsi_key &, 
                                  const void * = 0);
  basic_managed_xsi_shared_memory(basic_managed_xsi_shared_memory &&) noexcept;
  basic_managed_xsi_shared_memory & 
  operator=(basic_managed_xsi_shared_memory &&) noexcept;
  ~basic_managed_xsi_shared_memory();

  // public member functions
  void swap(basic_managed_xsi_shared_memory &) noexcept;
  int get_shmid() const noexcept;

  // public static functions
  static bool remove(int);
};

Description

A basic X/Open System Interface (XSI) shared memory named object creation class. Initializes the shared memory segment. Inherits all basic functionality from basic_managed_memory_impl<CharType, AllocationAlgorithm, IndexType>

basic_managed_xsi_shared_memory public construct/copy/destruct

  1. basic_managed_xsi_shared_memory() noexcept;

    Default constructor. Does nothing. Useful in combination with move semantics

  2. basic_managed_xsi_shared_memory(create_only_t, const xsi_key & key, 
                                    std::size_t size, const void * addr = 0, 
                                    const permissions & perm = permissions());

    Creates shared memory and creates and places the segment manager. This can throw.

  3. basic_managed_xsi_shared_memory(open_or_create_t, const xsi_key & key, 
                                    std::size_t size, const void * addr = 0, 
                                    const permissions & perm = permissions());

    Creates shared memory and creates and places the segment manager if segment was not created. If segment was created it connects to the segment. This can throw.

  4. basic_managed_xsi_shared_memory(open_read_only_t, const xsi_key & key, 
                                    const void * addr = 0);

    Connects to a created shared memory and its segment manager. in read-only mode. This can throw.

  5. basic_managed_xsi_shared_memory(open_only_t, const xsi_key & key, 
                                    const void * addr = 0);

    Connects to a created shared memory and its segment manager. This can throw.

  6. basic_managed_xsi_shared_memory(basic_managed_xsi_shared_memory && moved) noexcept;

    Moves the ownership of "moved"'s managed memory to *this. Does not throw

  7. basic_managed_xsi_shared_memory & 
    operator=(basic_managed_xsi_shared_memory && moved) noexcept;

    Moves the ownership of "moved"'s managed memory to *this. Does not throw

  8. ~basic_managed_xsi_shared_memory();

    Destroys *this and indicates that the calling process is finished using the resource. The destructor function will deallocate any system resources allocated by the system for use by this process for this resource. The resource can still be opened again calling the open constructor overload. To erase the resource from the system use remove().

basic_managed_xsi_shared_memory public member functions

  1. void swap(basic_managed_xsi_shared_memory & other) noexcept;

    Swaps the ownership of the managed shared memories managed by *this and other. Never throws.

  2. int get_shmid() const noexcept;

basic_managed_xsi_shared_memory public static functions

  1. static bool remove(int shmid);

    Erases a XSI shared memory object identified by shmid from the system. Returns false on error. Never throws


PrevUpHomeNext