|
BDE 4.14.0 Production release
|
#include <bslma_managedptr.h>
Static Public Member Functions | |
| static void | noOpDeleter (void *, void *) |
| Deleter function that does nothing. | |
| template<class ELEMENT_TYPE , class... ARGS> | |
| static ManagedPtr< ELEMENT_TYPE > | allocateManaged (bslma::Allocator *allocator, ARGS &&... args) |
| template<class ELEMENT_TYPE , class ALLOCATOR , class... ARGS> | |
| static bsl::enable_if< bsl::is_class< ALLOCATOR >::value, ManagedPtr< ELEMENT_TYPE > >::type | allocateManaged (const ALLOCATOR &allocator, ARGS &&... args) |
| template<class ELEMENT_TYPE , class... ARGS> | |
| static ManagedPtr< ELEMENT_TYPE > | makeManaged (ARGS &&... args) |
This utility class provides a general no-op deleter, which is useful when creating managed pointers to stack-allocated objects.
|
inlinestatic |
Create an object of the (template parameter) ELEMENT_TYPE from the specified args... arguments, and return a ManagedPtr to manage the new object. Use the specified allocator to supply memory for the footprint of the new object and implicitly pass allocator as the allocator argument to the ELEMENT_TYPE constructor if bslma::UsesBslmaAllocator<ELEMENT_TYPE>::value is true. If allocator is a null pointer, the currently installed default allocator is used. Note that compilation will fail unless allocator is convertible to either bslma::Allocator * or bsl::allocator<>.
|
inlinestatic |
|
inlinestatic |
Create an object of the (template parameter) ELEMENT_TYPE from the specified args... arguments, and return a ManagedPtr to manage the new object. Use the currently installed default allocator to supply memory for the footprint of the new object but do not implicitly pass the default allocator as the allocator argument to its constructor even if bslma::UsesBslmaAllocator<ELEMENT_TYPE>::value is true. Note that an allocator may be included in args, but see allocateManaged for an alternative function that is better suited to creating managed pointers to objects of allocator-aware type.
|
static |