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 |