Ocean
|
This class implements an accessor providing direct access to a constant array of elements. More...
#include <Accessor.h>
Public Types | |
typedef T | Type |
Definition of the element type of this accessor. | |
typedef size_t | KeyType |
Definition of the key (or e.g., index) type of this accessor. | |
Public Member Functions | |
ConstTemplateArrayAccessor ()=default | |
Creates a new empty accessor. | |
ConstTemplateArrayAccessor (ConstTemplateArrayAccessor< T > &&accessor) noexcept | |
Move constructor. | |
ConstTemplateArrayAccessor (const T *elements, const size_t size) | |
Creates a new accessor object. | |
ConstTemplateArrayAccessor (const std::vector< T > &elements) | |
Creates a new accessor object. | |
const T * | data () const |
Returns a pointer to the elements of this accessor if the data exists within one memory block without gaps. | |
size_t | size () const |
Returns the number of accessible elements of this accessor object. | |
bool | isEmpty () const |
Returns whether this accessor provides no elements. | |
bool | canAccess (const size_t &index) const |
Returns whether this accessor has a specific element. | |
bool | firstElement (T &element, size_t &index) const |
Returns the first element of this accessor. | |
bool | nextElement (const size_t &previousIndex, T &nextElement, size_t &nextIndex) const |
Returns the next element which follows a given key of the previous element. | |
const T & | operator[] (const size_t &index) const |
Returns one element of this accessor object. | |
ConstTemplateArrayAccessor< T > & | operator= (ConstArrayAccessor< T > &&accessor) noexcept |
Move operator. | |
Protected Attributes | |
const T * | elements_ = nullptr |
The elements of this accessor. | |
size_t | size_ = 0 |
The number of elements that can be accessed. | |
This class implements an accessor providing direct access to a constant array of elements.
An instance of this accessor does not copy the elements, thus the caller has to ensure that the actual elements exist as long as the instance of the accessor exists.
This class is not derived from Accessor (or any other Accessor class) to avoid virtual functions ensuring higher element-access performances.
Thus, this class will mainly be applied in template functions where the type of the accessor is defined at compile time.
The application of the this class is demonstrated in the following code example (compare the code example for ConstArrayAccessor):
T | The data type of the elements of the accessor |
typedef size_t Ocean::ConstTemplateArrayAccessor< T >::KeyType |
Definition of the key (or e.g., index) type of this accessor.
typedef T Ocean::ConstTemplateArrayAccessor< T >::Type |
Definition of the element type of this accessor.
|
default |
Creates a new empty accessor.
|
inlinenoexcept |
Move constructor.
accessor | Accessor to be moved |
|
inline |
Creates a new accessor object.
Beware: The given elements are not copied, they must not be deleted before the accessor is disposed.
elements | The elements that can be accessed, may be nullptr if size is equal 0 |
size | The number of elements that can be accessed, may be 0 if elements is nullptr |
|
inlineexplicit |
Creates a new accessor object.
Beware: The given elements are not copied, they must not be deleted before the accessor is disposed.
elements | A vector holding all elements |
|
inline |
Returns whether this accessor has a specific element.
|
inline |
Returns a pointer to the elements of this accessor if the data exists within one memory block without gaps.
|
inline |
Returns the first element of this accessor.
|
inline |
Returns whether this accessor provides no elements.
|
inline |
Returns the next element which follows a given key of the previous element.
|
inlinenoexcept |
|
inline |
Returns one element of this accessor object.
|
inline |
Returns the number of accessible elements of this accessor object.
|
protected |
The elements of this accessor.
|
protected |
The number of elements that can be accessed.