Table of Contents
- Summary
- Template Parameters
- Public Member Types
- Public Data Members
- Public Member Functions
- (constructor)
- (destructor)
- assign
- assign_range
- operator=
- get_allocator
- begin, cbegin
- end, cend
- rbegin, crbegin
- rend, crend
- nth
- index_of
- empty
- size
- max_size
- capacity
- available
- reserve
- shrink_to_fit
- at
- operator[]
- front
- back
- data
- clear
- emplace
- insert
- insert_range
- emplace_back
- push_back
- append_range
- pop_back
- erase
- resize
- swap
- Non-member Functions
Defined in header sfl/small_vector.hpp:
namespace sfl
{
template < typename T,
std::size_t N,
typename Allocator = std::allocator<T> >
class small_vector;
}
sfl::small_vector is a sequence container similar to std::vector, but it internally holds a statically allocated array of size N and stores elements in this array until the number of elements exceeds N, which avoids dynamic memory allocation and deallocation. Dynamic memory management is used when the number of elements exceeds N. This design provides a compact and cache-friendly representation optimized for small sizes.
sfl::small_vector is not specialized for bool.
sfl::small_vector meets the requirements of Container, AllocatorAwareContainer, ReversibleContainer, ContiguousContainer and SequenceContainer.
-
typename TThe type of the elements.
-
std::size_t NSize of the internal statically allocated array, i.e. the maximal number of elements that can fit into this array.
This parameter can be zero.
-
typename AllocatorAllocator used for memory allocation/deallocation and construction/destruction of elements.
This type must meet the requirements of Allocator.
The program is ill-formed if
Allocator::value_typeis not the same asT.
| Member Type | Definition |
|---|---|
allocator_type |
Allocator |
value_type |
T |
size_type |
Unsigned integer type |
difference_type |
Signed integer type |
reference |
T& |
const_reference |
const T& |
pointer |
Pointer to value_type |
const_pointer |
Pointer to const value_type |
iterator |
LegacyRandomAccessIterator and LegacyContiguousIterator to value_type |
const_iterator |
LegacyRandomAccessIterator and LegacyContiguousIterator to const value_type |
reverse_iterator |
std::reverse_iterator<iterator> |
const_reverse_iterator |
std::reverse_iterator<const_iterator> |
static constexpr size_type static_capacity = N;
-
small_vector() noexcept; -
explicit small_vector(const Allocator& alloc) noexcept(std::is_nothrow_copy_constructible<Allocator>::value);Effects: Constructs an empty container.
Complexity: Constant.
-
small_vector(size_type n); -
explicit small_vector(size_type n, const Allocator& alloc);Effects: Constructs the container with
ndefault-constructed elements.Complexity: Linear in
n. -
small_vector(size_type n, const T& value); -
small_vector(size_type n, const T& value, const Allocator& alloc);Effects: Constructs the container with
ncopies of elements with valuevalue.Complexity: Linear in
n. -
template <typename InputIt> small_vector(InputIt first, InputIt last); -
template <typename InputIt> small_vector(InputIt first, InputIt last, const Allocator& alloc);Effects: Constructs the container with the contents of the range
[first, last).Note: This overload participates in overload resolution only if
InputItsatisfies requirements of LegacyInputIterator.Complexity: Linear in
std::distance(first, last). -
small_vector(std::initializer_list<T> ilist); -
small_vector(std::initializer_list<T> ilist, const Allocator& alloc);Effects: Constructs the container with the contents of the initializer list
ilist.Complexity: Linear in
ilist.size(). -
small_vector(const small_vector& other); -
small_vector(const small_vector& other, const Allocator& alloc);Effects: Copy constructor. Constructs the container with the copy of the contents of
other.Complexity: Linear in
other.size(). -
small_vector(small_vector&& other); -
small_vector(small_vector&& other, const Allocator& alloc);Effects: Move constructor. Constructs the container with the contents of
otherusing move semantics.otheris not guaranteed to be empty after the move.otheris in a valid but unspecified state after the move.Complexity: Constant in the best case. Linear in
Nin the worst case. -
template <typename Range> small_vector(sfl::from_range_t, Range&& range); -
template <typename Range> small_vector(sfl::from_range_t, Range&& range, const Allocator& alloc);Effects: Constructs the container with the contents of
range.Note: It is available in C++11. In C++20 are used proper C++20 range concepts.
-
~small_vector();Effects: Destructs the container. The destructors of the elements are called and the used storage is deallocated.
Complexity: Linear in
size().
-
void assign(size_type n, const T& value);Effects: Replaces the contents of the container with
ncopies of valuevalue.Complexity: Linear in
n. -
template <typename InputIt> void assign(InputIt first, InputIt last);Effects: Replaces the contents of the container with the contents of the range
[first, last).Note: This overload participates in overload resolution only if
InputItsatisfies requirements of LegacyInputIterator.Note: The behavior is undefined if either
firstorlastis an iterator into*this.Complexity: Linear in
std::distance(first, last). -
void assign(std::initializer_list<T> ilist);Effects: Replaces the contents of the container with the contents of the initializer list
ilist.Complexity: Linear in
ilist.size().
-
template <typename Range> void assign_range(Range&& range);Effects: Replaces the contents of the container with the contents of
range.Note: It is available in C++11. In C++20 are used proper C++20 range concepts.
-
small_vector& operator=(const small_vector& other);Effects: Copy assignment operator. Replaces the contents with a copy of the contents of
other.Returns:
*this().Complexity: Linear in
this->size()plus linear inother.size(). -
small_vector& operator=(small_vector&& other);Effects: Move assignment operator. Replaces the contents with those of
otherusing move semantics.otheris not guaranteed to be empty after the move.otheris in a valid but unspecified state after the move.Returns:
*this().Complexity:
- The best case: Linear in
this->size()plus constant. - The worst case: Linear in
this->size()plus linear inother.size().
- The best case: Linear in
-
small_vector& operator=(std::initializer_list<T> ilist);Effects: Replaces the contents with those identified by initializer list
ilist.Returns:
*this().Complexity: Linear in
this->size()plus linear inilist.size().
-
allocator_type get_allocator() const noexcept;Effects: Returns the allocator associated with the container.
Complexity: Constant.
-
iterator begin() noexcept; -
const_iterator begin() const noexcept; -
const_iterator cbegin() const noexcept;Effects: Returns an iterator to the first element of the container. If the container is empty, the returned iterator will be equal to
end().Complexity: Constant.
-
iterator end() noexcept; -
const_iterator end() const noexcept; -
const_iterator cend() const noexcept;Effects: Returns an iterator to the element following the last element of the container. This element acts as a placeholder; attempting to access it results in undefined behavior.
Complexity: Constant.
-
reverse_iterator rbegin() noexcept; -
const_reverse_iterator rbegin() const noexcept; -
const_reverse_iterator crbegin() const noexcept;Effects: Returns a reverse iterator to the first element of the reversed container. It corresponds to the last element of the non-reversed container. If the container is empty, the returned iterator is equal to
rend().Complexity: Constant.
-
reverse_iterator rend() noexcept; -
const_reverse_iterator rend() const noexcept; -
const_reverse_iterator crend() const noexcept;Effects: Returns a reverse iterator to the element following the last element of the reversed container. It corresponds to the element preceding the first element of the non-reversed container. This element acts as a placeholder, attempting to access it results in undefined behavior.
Complexity: Constant.
-
iterator nth(size_type pos) noexcept; -
const_iterator nth(size_type pos) const noexcept;Preconditions:
pos <= size()Effects: Returns an iterator to the element at position
pos.If
pos == size(), the returned iterator is equal toend().Complexity: Constant.
-
size_type index_of(const_iterator pos) const noexcept;Preconditions:
cbegin() <= pos && pos <= cend()Effects: Returns position of the element pointed by iterator
pos, i.e.std::distance(begin(), pos).If
pos == end(), the returned value is equal tosize().Complexity: Constant.
-
bool empty() const noexcept;Effects: Returns
trueif the container has no elements, i.e. whetherbegin() == end().Complexity: Constant.
-
size_type size() const noexcept;Effects: Returns the number of elements in the container, i.e.
std::distance(begin(), end()).Complexity: Constant.
-
size_type max_size() const noexcept;Effects: Returns the maximum number of elements the container is able to hold, i.e.
std::distance(begin(), end())for the largest container.Complexity: Constant.
-
size_type capacity() const noexcept;Effects: Returns the number of elements that the container has currently allocated space for.
Complexity: Constant.
-
size_type available() const noexcept;Effects: Returns the number of elements that can be inserted into the container without requiring allocation of additional memory.
Complexity: Constant.
-
void reserve(size_type new_cap);Effects: Tries to increase capacity by allocating additional memory.
If
new_cap > capacity(), the function allocates memory for new storage of capacity equal to the value ofnew_cap, moves elements from old storage to new storage, and deallocates memory used by old storage. Otherwise, the function does nothing.This function does not change size of the container.
If the capacity is changed, all iterators and all references to the elements are invalidated. Otherwise, no iterators or references are invalidated.
Complexity: Linear.
Exceptions:
Allocator::allocatemay throw.T's move or copy constructor may throw.
If an exception is thrown:
- If type
Thas availablenoexceptmove constructor:- This function has no effects (strong exception guarantee).
- Else if type
Thas available copy constructor:- This function has no effects (strong exception guarantee).
- Else if type
Thas available throwing move constructor:- Container is changed but in valid state (basic exception guarantee).
-
void shrink_to_fit();Effects: Tries to reduce memory usage by freeing unused memory.
-
If
size() > N && size() < capacity(), the function allocates memory for new storage of capacity equal to the value ofsize(), moves elements from old storage to new storage, and deallocates memory used by old storage. -
If
size() <= N && N < capacity(), the function sets new storage to be internal statically allocated array of capacityN, moves elements from old storage to new storage, and deallocates memory used by old storage. -
Otherwise the function does nothing.
This function does not change size of the container.
If the capacity is changed, all iterators and all references to the elements are invalidated. Otherwise, no iterators or references are invalidated.
Complexity: Linear.
Exceptions:
Allocator::allocatemay throw.T's move or copy constructor may throw.
If an exception is thrown:
- If type
Thas availablenoexceptmove constructor:- This function has no effects (strong exception guarantee).
- Else if type
Thas available copy constructor:- This function has no effects (strong exception guarantee).
- Else if type
Thas available throwing move constructor:- Container is changed but in valid state (basic exception guarantee).
-
-
reference at(size_type pos); -
const_reference at(size_type pos) const;Effects: Returns a reference to the element at specified location
pos, with bounds checking.Complexity: Constant.
Exceptions:
std::out_of_rangeifpos >= size().
-
reference operator[](size_type pos) noexcept; -
const_reference operator[](size_type pos) const noexcept;Preconditions:
pos < size()Effects: Returns a reference to the element at specified location pos. No bounds checking is performed.
Note: This operator never inserts a new element into the container.
Complexity: Constant.
-
reference front() noexcept; -
const_reference front() const noexcept;Preconditions:
!empty()Effects: Returns a reference to the first element in the container.
Complexity: Constant.
-
reference back() noexcept; -
const_reference back() const noexcept;Preconditions:
!empty()Effects: Returns a reference to the last element in the container.
Complexity: Constant.
-
T* data() noexcept; -
const T* data() const noexcept;Effects: Returns pointer to the underlying array serving as element storage. The pointer is such that range
[data(), data() + size())is always a valid range, even if the container is empty.data()is not dereferenceable if the container is empty.Complexity: Constant.
-
void clear() noexcept;Effects: Erases all elements from the container. After this call,
size()returns zero andcapacity()remains unchanged.Complexity: Linear in
size().
-
template <typename... Args> iterator emplace(const_iterator pos, Args&&... args);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts a new element into the container at position
pos.New element is constructed as
value_type(std::forward<Args>(args)...).args...may directly or indirectly refer to a value in the container.Returns: Iterator to the inserted element.
Complexity: Constant plus linear in
std::distance(pos, end()).
-
iterator insert(const_iterator pos, const T& value);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts copy of
valueat positionpos.Returns: Iterator to the inserted element.
Complexity: Constant plus linear in
std::distance(pos, end()). -
iterator insert(const_iterator pos, T&& value);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts
valueusing move semantics at positionpos.Returns: Iterator to the inserted element.
Complexity: Constant plus linear in
std::distance(pos, end()). -
iterator insert(const_iterator pos, size_type n, const T& value);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts
ncopies ofvaluebefore positionpos.Returns: Iterator to the first element inserted, or
posifn == 0.Complexity: Linear in
nplus linear instd::distance(pos, end()). -
template <typename InputIt> iterator insert(const_iterator pos, InputIt first, InputIt last);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts elements from the range
[first, last)before positionpos.Note: This overload participates in overload resolution only if
InputItsatisfies requirements of LegacyInputIterator.Note: The behavior is undefined if either
firstorlastis an iterator into*this.Returns: Iterator to the first element inserted, or
posiffirst == last.Complexity: Linear in
std::distance(first, last)plus linear instd::distance(pos, end()). -
iterator insert(const_iterator pos, std::initializer_list<T> ilist);Preconditions:
cbegin() <= pos && pos <= cend()Effects: Inserts elements from initializer list
ilistbefore positionpos.Returns: Iterator to the first element inserted, or
posifilistis empty.Complexity: Linear in
ilist.size()plus linear instd::distance(pos, end()).
-
template <typename Range> iterator insert_range(const_iterator pos, Range&& range);Effects: Inserts elements from
rangebefore positionpos. Elements are inserted in non-reversing order.rangemust not overlap with the container. Otherwise, the behavior is undefined.Returns: Iterator to the first element inserted, or
posifrangeis empty.Note: It is available in C++11. In C++20 are used proper C++20 range concepts.
-
template <typename... Args> reference emplace_back(Args&&... args);Effects: Inserts a new element at the end of container.
New element is constructed as
value_type(std::forward<Args>(args)...).Returns: Reference to the inserted element.
Complexity: Constant.
-
void push_back(const T& value);Effects: Inserts copy of
valueat the end of container.Complexity: Constant.
-
void push_back(T&& value);Effects: Inserts
valueusing move semantics at the end of container.Complexity: Constant.
-
template <typename Range> void append_range(Range&& range);Effects: Inserts elements from
rangebeforeend(). Elements are inserted in non-reversing order.Note: It is available in C++11. In C++20 are used proper C++20 range concepts.
-
void pop_back();Preconditions:
!empty()Effects: Removes the last element of the container.
Complexity: Constant.
-
iterator erase(const_iterator pos);Preconditions:
cbegin() <= pos && pos < cend()Effects: Removes the element at
pos.Returns: Iterator following the last removed element.
If
posrefers to the last element, then theend()iterator is returned. -
iterator erase(const_iterator first, const_iterator last);Preconditions:
cbegin() <= first && first <= last && last <= cend()Effects: Removes the elements in the range
[first, last).Returns: Iterator following the last removed element.
If
last == end()prior to removal, then the updatedend()iterator is returned.If
[first, last)is an empty range, thenlastis returned.
-
void resize(size_type n);Effects: Resizes the container to contain
nelements.- If the
size() > n, the lastsize() - nelements are removed. - If the
size() < n, additional default-constructed elements are inserted at the end of container.
Complexity: Linear in difference between
size()andn. Additional complexity possible due to reallocation ifn > capacity(). - If the
-
void resize(size_type n, const T& value);Effects: Resizes the container to contain
nelements.- If the
size() > n, the lastsize() - nelements are removed. - If the
size() < n, additional copies ofvalueare inserted at the end of container.
Complexity: Linear in difference between
size()andn. Additional complexity possible due to reallocation ifn > capacity(). - If the
-
void swap(small_vector& other);Preconditions:
std::allocator_traits<allocator_type>::propagate_on_container_swap::value || get_allocator() == other.get_allocator()Effects: Exchanges the contents of the container with those of
other.Complexity: Constant in the best case. Linear in
this->size()plus linear inother.size()in the worst case.
-
template <typename T, std::size_t N, typename A> bool operator== ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Checks if the contents of
xandyare equal.The contents of
xandyare equal if the following conditions hold:x.size() == y.size()- Each element in
xcompares equal with the element inyat the same position.
Returns:
trueif the contents of thexandyare equal,falseotherwise.Complexity: Constant if
xandyare of different size, otherwise linear in the size of the container.
-
template <typename T, std::size_t N, typename A> bool operator!= ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Checks if the contents of
xandyare equal.For details see
operator==.Returns:
trueif the contents of thexandyare not equal,falseotherwise.Complexity: Constant if
xandyare of different size, otherwise linear in the size of the container.
-
template <typename T, std::size_t N, typename A> bool operator< ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Compares the contents of
xandylexicographically. The comparison is performed by a functionstd::lexicographical_compare.Returns:
trueif the contents of thexare lexicographically less than the contents ofy,falseotherwise.Complexity: Linear in the size of the container.
-
template <typename T, std::size_t N, typename A> bool operator> ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Compares the contents of
xandylexicographically. The comparison is performed by a functionstd::lexicographical_compare.Returns:
trueif the contents of thexare lexicographically greater than the contents ofy,falseotherwise.Complexity: Linear in the size of the container.
-
template <typename T, std::size_t N, typename A> bool operator<= ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Compares the contents of
xandylexicographically. The comparison is performed by a functionstd::lexicographical_compare.Returns:
trueif the contents of thexare lexicographically less than or equal to the contents ofy,falseotherwise.Complexity: Linear in the size of the container.
-
template <typename T, std::size_t N, typename A> bool operator>= ( const small_vector<T, N, A>& x, const small_vector<T, N, A>& y );Effects: Compares the contents of
xandylexicographically. The comparison is performed by a functionstd::lexicographical_compare.Returns:
trueif the contents of thexare lexicographically greater than or equal to the contents ofy,falseotherwise.Complexity: Linear in the size of the container.
-
template <typename T, std::size_t N, typename A> void swap ( small_vector<T, N, A>& x, small_vector<T, N, A>& y );Effects: Swaps the contents of
xandy. Callsx.swap(y).
-
template <typename T, std::size_t N, typename A, typename U> typename small_vector<T, N, A>::size_type erase(small_vector<T, N, A>& c, const U& value);Effects: Erases all elements that compare equal to
valuefrom the container.Returns: The number of erased elements.
Complexity: Linear.
-
template <typename T, std::size_t N, typename A, typename Predicate> typename small_vector<T, N, A>::size_type erase_if(small_vector<T, N, A>& c, Predicate pred);Effects: Erases all elements that satisfy the predicate
predfrom the container.predis unary predicate which returnstrueif the element should be removed.Returns: The number of erased elements.
Complexity: Linear.
End of document.