MFEM  v4.6.0
Finite element discretization library
Classes | Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
mfem::BlockArray< T > Class Template Reference

#include <array.hpp>

Inheritance diagram for mfem::BlockArray< T >:
[legend]
Collaboration diagram for mfem::BlockArray< T >:
[legend]

Classes

class  const_iterator
 
class  iterator
 
class  iterator_base
 

Public Member Functions

 BlockArray (int block_size=16 *1024)
 
 BlockArray (const BlockArray< T > &other)
 
BlockArrayoperator= (const BlockArray &)=delete
 
 ~BlockArray ()
 
int Append ()
 Allocate and construct a new item in the array, return its index. More...
 
int Append (const T &item)
 Allocate and copy-construct a new item in the array, return its index. More...
 
T & At (int index)
 Access item of the array. More...
 
const T & At (int index) const
 
T & operator[] (int index)
 Access item of the array. More...
 
const T & operator[] (int index) const
 
int Size () const
 Return the number of items actually stored. More...
 
int Capacity () const
 Return the current capacity of the BlockArray. More...
 
void DeleteAll ()
 Destroy all items, set size to zero. More...
 
void Swap (BlockArray< T > &other)
 
std::size_t MemoryUsage () const
 
iterator begin ()
 
iterator end ()
 
const_iterator cbegin () const
 
const_iterator cend () const
 

Protected Member Functions

int Alloc ()
 
void CheckIndex (int index) const
 
void Destroy ()
 

Protected Attributes

Array< T * > blocks
 
int size
 
int shift
 
int mask
 

Detailed Description

template<typename T>
class mfem::BlockArray< T >

A container for items of type T. Dynamically grows as items are added. Each item is accessible by its index. Items are allocated in larger chunks (blocks), so the 'Append' method is very fast on average.

Definition at line 479 of file array.hpp.

Constructor & Destructor Documentation

◆ BlockArray() [1/2]

template<typename T >
mfem::BlockArray< T >::BlockArray ( int  block_size = 16*1024)

Definition at line 984 of file array.hpp.

◆ BlockArray() [2/2]

template<typename T>
mfem::BlockArray< T >::BlockArray ( const BlockArray< T > &  other)

Definition at line 994 of file array.hpp.

◆ ~BlockArray()

template<typename T>
mfem::BlockArray< T >::~BlockArray ( )
inline

Definition at line 485 of file array.hpp.

Member Function Documentation

◆ Alloc()

template<typename T >
int mfem::BlockArray< T >::Alloc ( )
protected

Definition at line 1016 of file array.hpp.

◆ Append() [1/2]

template<typename T >
int mfem::BlockArray< T >::Append ( )

Allocate and construct a new item in the array, return its index.

Definition at line 1028 of file array.hpp.

◆ Append() [2/2]

template<typename T>
int mfem::BlockArray< T >::Append ( const T &  item)

Allocate and copy-construct a new item in the array, return its index.

Definition at line 1036 of file array.hpp.

◆ At() [1/2]

template<typename T>
T& mfem::BlockArray< T >::At ( int  index)
inline

Access item of the array.

Definition at line 494 of file array.hpp.

◆ At() [2/2]

template<typename T>
const T& mfem::BlockArray< T >::At ( int  index) const
inline

Definition at line 499 of file array.hpp.

◆ begin()

template<typename T>
iterator mfem::BlockArray< T >::begin ( )
inline

Definition at line 604 of file array.hpp.

◆ Capacity()

template<typename T>
int mfem::BlockArray< T >::Capacity ( ) const
inline

Return the current capacity of the BlockArray.

Definition at line 513 of file array.hpp.

◆ cbegin()

template<typename T>
const_iterator mfem::BlockArray< T >::cbegin ( ) const
inline

Definition at line 607 of file array.hpp.

◆ cend()

template<typename T>
const_iterator mfem::BlockArray< T >::cend ( ) const
inline

Definition at line 609 of file array.hpp.

◆ CheckIndex()

template<typename T>
void mfem::BlockArray< T >::CheckIndex ( int  index) const
inlineprotected

Definition at line 617 of file array.hpp.

◆ DeleteAll()

template<typename T>
void mfem::BlockArray< T >::DeleteAll ( )
inline

Destroy all items, set size to zero.

Definition at line 516 of file array.hpp.

◆ Destroy()

template<typename T >
void mfem::BlockArray< T >::Destroy ( )
protected

Definition at line 1059 of file array.hpp.

◆ end()

template<typename T>
iterator mfem::BlockArray< T >::end ( )
inline

Definition at line 605 of file array.hpp.

◆ MemoryUsage()

template<typename T >
std::size_t mfem::BlockArray< T >::MemoryUsage ( ) const

Definition at line 1053 of file array.hpp.

◆ operator=()

template<typename T>
BlockArray& mfem::BlockArray< T >::operator= ( const BlockArray< T > &  )
delete

◆ operator[]() [1/2]

template<typename T>
T& mfem::BlockArray< T >::operator[] ( int  index)
inline

Access item of the array.

Definition at line 506 of file array.hpp.

◆ operator[]() [2/2]

template<typename T>
const T& mfem::BlockArray< T >::operator[] ( int  index) const
inline

Definition at line 507 of file array.hpp.

◆ Size()

template<typename T>
int mfem::BlockArray< T >::Size ( ) const
inline

Return the number of items actually stored.

Definition at line 510 of file array.hpp.

◆ Swap()

template<typename T>
void mfem::BlockArray< T >::Swap ( BlockArray< T > &  other)

Definition at line 1044 of file array.hpp.

Member Data Documentation

◆ blocks

template<typename T>
Array<T*> mfem::BlockArray< T >::blocks
protected

Definition at line 612 of file array.hpp.

◆ mask

template<typename T>
int mfem::BlockArray< T >::mask
protected

Definition at line 613 of file array.hpp.

◆ shift

template<typename T>
int mfem::BlockArray< T >::shift
protected

Definition at line 613 of file array.hpp.

◆ size

template<typename T>
int mfem::BlockArray< T >::size
protected

Definition at line 613 of file array.hpp.


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