WPILibC++ 2025.1.1
Loading...
Searching...
No Matches
wpi::memory::allocator_deallocator< Type, RawAllocator > Class Template Reference

A deleter class that deallocates the memory through a specified RawAllocator. More...

#include <wpi/memory/deleter.hpp>

Public Types

using allocator_type = typename allocator_reference<RawAllocator>::allocator_type
 
using value_type = Type
 

Public Member Functions

 allocator_deallocator () noexcept=default
 
 allocator_deallocator (allocator_reference< RawAllocator > alloc) noexcept
 
void operator() (value_type *pointer) noexcept
 
auto get_allocator () const noexcept -> decltype(std::declval< allocator_reference< allocator_type > >().get_allocator())
 

Detailed Description

template<typename Type, class RawAllocator>
class wpi::memory::allocator_deallocator< Type, RawAllocator >

A deleter class that deallocates the memory through a specified RawAllocator.

It deallocates memory for a specified type but does not call its destructors.

Member Typedef Documentation

◆ allocator_type

template<typename Type , class RawAllocator >
using wpi::memory::allocator_deallocator< Type, RawAllocator >::allocator_type = typename allocator_reference<RawAllocator>::allocator_type

◆ value_type

template<typename Type , class RawAllocator >
using wpi::memory::allocator_deallocator< Type, RawAllocator >::value_type = Type

Constructor & Destructor Documentation

◆ allocator_deallocator() [1/2]

template<typename Type , class RawAllocator >
wpi::memory::allocator_deallocator< Type, RawAllocator >::allocator_deallocator ( )
defaultnoexcept
Effects:
Creates it without any associated allocator. The deallocator must not be used if that is the case.
Notes:
This functions is useful if you have want to create an empty smart pointer without giving it an allocator.

◆ allocator_deallocator() [2/2]

template<typename Type , class RawAllocator >
wpi::memory::allocator_deallocator< Type, RawAllocator >::allocator_deallocator ( allocator_reference< RawAllocator > alloc)
inlinenoexcept
Effects:
Creates it by passing it an allocator_reference. It will store the reference to it and uses the referenced allocator object for the deallocation.

Member Function Documentation

◆ get_allocator()

template<typename Type , class RawAllocator >
auto wpi::memory::allocator_deallocator< Type, RawAllocator >::get_allocator ( ) const -> decltype(std::declval<allocator_reference<allocator_type>>().get_allocator())
inlinenoexcept
Returns:
The reference to the allocator. It has the same type as the call to allocator_reference::get_allocator().
Requires:
The deallocator must not be created by the default constructor.

◆ operator()()

template<typename Type , class RawAllocator >
void wpi::memory::allocator_deallocator< Type, RawAllocator >::operator() ( value_type * pointer)
inlinenoexcept
Effects:
Deallocates the memory given to it. Calls deallocate_node(pointer, sizeof(value_type), alignof(value_type)) on the referenced allocator object.
Requires:
The deallocator must not have been created by the default constructor.

The documentation for this class was generated from the following file: