[forwardlist] (original) (raw)
22 Containers library [containers]
22.3 Sequence containers [sequences]
22.3.9 Class template forward_list [forwardlist]
22.3.9.1 Overview [forwardlist.overview]
A forward_list is a container that supports forward iterators and allows constant time insert and erase operations anywhere within the sequence, with storage management handled automatically.
Fast random access to list elements is not supported.
[ Note
:
It is intended that forward_list have zero space or time overhead relative to a hand-written C-style singly linked list.
Features that would conflict with that goal have been omitted.
— end note
]
A forward_list meets all of the requirements of a container (Table 73), except that the size()member function is not provided and operator== has linear complexity.
A forward_list also meets all of the requirements for an allocator-aware container (Table 76).
In addition, a forward_listprovides the assign member functions (Table 77) and several of the optional container requirements (Table 78).
Descriptions are provided here only for operations onforward_list that are not described in that table or for operations where there is additional semantic information.
[ Note
:
Modifying any list requires access to the element preceding the first element of interest, but in a forward_list there is no constant-time way to access a preceding element.
For this reason, ranges that are modified, such as those supplied toerase and splice, must be open at the beginning.
— end note
]
namespace std { template<class T, class Allocator = allocator> class forward_list { public:
using value_type = T;
using allocator_type = Allocator;
using pointer = typename allocator_traits<Allocator>::pointer;
using const_pointer = typename allocator_traits<Allocator>::const_pointer;
using reference = value_type&;
using const_reference = const value_type&;
using size_type = implementation-defined;
using difference_type = implementation-defined;
using iterator = implementation-defined;
using const_iterator = implementation-defined;
forward_list() : forward_list(Allocator()) { }
explicit forward_list(const Allocator&);
explicit forward_list(size_type n, const Allocator& = Allocator());
forward_list(size_type n, const T& value, const Allocator& = Allocator());
template<class InputIterator>
forward_list(InputIterator first, InputIterator last, const Allocator& = Allocator());
forward_list(const forward_list& x);
forward_list(forward_list&& x);
forward_list(const forward_list& x, const Allocator&);
forward_list(forward_list&& x, const Allocator&);
forward_list(initializer_list<T>, const Allocator& = Allocator());
~forward_list();
forward_list& operator=(const forward_list& x);
forward_list& operator=(forward_list&& x)
noexcept(allocator_traits<Allocator>::is_always_equal::value);
forward_list& operator=(initializer_list<T>);
template<class InputIterator>
void assign(InputIterator first, InputIterator last);
void assign(size_type n, const T& t);
void assign(initializer_list<T>);
allocator_type get_allocator() const noexcept;
iterator before_begin() noexcept;
const_iterator before_begin() const noexcept;
iterator begin() noexcept;
const_iterator begin() const noexcept;
iterator end() noexcept;
const_iterator end() const noexcept;
const_iterator cbegin() const noexcept;
const_iterator cbefore_begin() const noexcept;
const_iterator cend() const noexcept;
[[nodiscard]] bool empty() const noexcept;
size_type max_size() const noexcept;
reference front();
const_reference front() const;
template<class... Args> reference emplace_front(Args&&... args);
void push_front(const T& x);
void push_front(T&& x);
void pop_front();
template<class... Args> iterator emplace_after(const_iterator position, Args&&... args);
iterator insert_after(const_iterator position, const T& x);
iterator insert_after(const_iterator position, T&& x);
iterator insert_after(const_iterator position, size_type n, const T& x);
template<class InputIterator>
iterator insert_after(const_iterator position, InputIterator first, InputIterator last);
iterator insert_after(const_iterator position, initializer_list<T> il);
iterator erase_after(const_iterator position);
iterator erase_after(const_iterator position, const_iterator last);
void swap(forward_list&)
noexcept(allocator_traits<Allocator>::is_always_equal::value);
void resize(size_type sz);
void resize(size_type sz, const value_type& c);
void clear() noexcept;
void splice_after(const_iterator position, forward_list& x);
void splice_after(const_iterator position, forward_list&& x);
void splice_after(const_iterator position, forward_list& x, const_iterator i);
void splice_after(const_iterator position, forward_list&& x, const_iterator i);
void splice_after(const_iterator position, forward_list& x,
const_iterator first, const_iterator last);
void splice_after(const_iterator position, forward_list&& x,
const_iterator first, const_iterator last);
size_type remove(const T& value);
template<class Predicate> size_type remove_if(Predicate pred);
size_type unique();
template<class BinaryPredicate> size_type unique(BinaryPredicate binary_pred);
void merge(forward_list& x);
void merge(forward_list&& x);
template<class Compare> void merge(forward_list& x, Compare comp);
template<class Compare> void merge(forward_list&& x, Compare comp);
void sort();
template<class Compare> void sort(Compare comp);
void reverse() noexcept;};
template<class InputIterator, class Allocator = allocator<iter-value-type>> forward_list(InputIterator, InputIterator, Allocator = Allocator()) -> forward_list<iter-value-type, Allocator>;
template<class T, class Allocator> void swap(forward_list<T, Allocator>& x, forward_list<T, Allocator>& y) noexcept(noexcept(x.swap(y))); }
T shall be complete before any member of the resulting specialization of forward_list is referenced.
22.3.9.2 Constructors, copy, and assignment [forwardlist.cons]
explicit forward_list(const Allocator&);
Effects:Constructs an empty forward_list object using the specified allocator.
explicit forward_list(size_type n, const Allocator& = Allocator());
Preconditions: T is Cpp17DefaultInsertable into *this.
Effects:Constructs a forward_list object with ndefault-inserted elements using the specified allocator.
forward_list(size_type n, const T& value, const Allocator& = Allocator());
Preconditions: T is Cpp17CopyInsertable into *this.
Effects:Constructs a forward_list object with n copies of value using the specified allocator.
template<class InputIterator> forward_list(InputIterator first, InputIterator last, const Allocator& = Allocator());
Effects:Constructs a forward_list object equal to the range [first, last).
Complexity:Linear in distance(first, last).
22.3.9.3 Iterators [forwardlist.iter]
iterator before_begin() noexcept; const_iterator before_begin() const noexcept; const_iterator cbefore_begin() const noexcept;
Returns:A non-dereferenceable iterator that, when incremented, is equal to the iterator returned by begin().
Effects: cbefore_begin() is equivalent toconst_cast<forward_list const&>(*this).before_begin().
Remarks: before_begin() == end() shall equal false.
22.3.9.5 Modifiers [forwardlist.modifiers]
None of the overloads of insert_after shall affect the validity of iterators and references, and erase_after shall invalidate only iterators and references to the erased elements.
If an exception is thrown during insert_after there shall be no effect.
Inserting n elements into a forward_list is linear inn, and the number of calls to the copy or move constructor of T is exactly equal to n.
Erasing n elements from a forward_list is linear in n and the number of calls to the destructor of type T is exactly equal to n.
template<class... Args> reference emplace_front(Args&&... args);
Effects:Inserts an object of type value_type constructed withvalue_type(std::forward<Args>(args)...) at the beginning of the list.
void push_front(const T& x);void push_front(T&& x);
Effects:Inserts a copy of x at the beginning of the list.
Effects:As if by erase_after(before_begin()).
iterator insert_after(const_iterator position, const T& x); iterator insert_after(const_iterator position, T&& x);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
Effects:Inserts a copy of x after position.
Returns:An iterator pointing to the copy of x.
iterator insert_after(const_iterator position, size_type n, const T& x);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
Effects:Inserts n copies of x after position.
Returns:An iterator pointing to the last inserted copy of x or position if n == 0.
template<class InputIterator> iterator insert_after(const_iterator position, InputIterator first, InputIterator last);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
Neither first nor last are iterators in *this.
Effects:Inserts copies of elements in [first, last) after position.
Returns:An iterator pointing to the last inserted element or position if first == last.
iterator insert_after(const_iterator position, initializer_list<T> il);
Effects: insert_after(p, il.begin(), il.end()).
Returns:An iterator pointing to the last inserted element or position if il is empty.
template<class... Args> iterator emplace_after(const_iterator position, Args&&... args);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
Effects:Inserts an object of type value_type constructed withvalue_type(std::forward<Args>(args)...) after position.
Returns:An iterator pointing to the new object.
iterator erase_after(const_iterator position);
Preconditions:The iterator following position is dereferenceable.
Effects:Erases the element pointed to by the iterator following position.
Returns:An iterator pointing to the element following the one that was erased, or end() if no such element exists.
iterator erase_after(const_iterator position, const_iterator last);
Preconditions:All iterators in the range (position, last) are dereferenceable.
Effects:Erases the elements in the range (position, last).
void resize(size_type sz);
Preconditions: T is Cpp17DefaultInsertable into *this.
Effects:If sz < distance(begin(), end()), erases the last distance(begin(), end()) - sz elements from the list.
Otherwise, inserts sz - distance(begin(), end()) default-inserted elements at the end of the list.
void resize(size_type sz, const value_type& c);
Preconditions: T is Cpp17CopyInsertable into *this.
Effects:If sz < distance(begin(), end()), erases the last distance(begin(), end()) - sz elements from the list.
Otherwise, inserts sz - distance(begin(), end())copies of c at the end of the list.
Effects:Erases all elements in the range [begin(), end()).
Remarks:Does not invalidate past-the-end iterators.
22.3.9.6 Operations [forwardlist.ops]
In this subclause, arguments for a template parameter named Predicate or BinaryPredicateshall meet the corresponding requirements in [algorithms.requirements].
For merge and sort, the definitions and requirements in [alg.sorting] apply.
void splice_after(const_iterator position, forward_list& x);void splice_after(const_iterator position, forward_list&& x);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
get_allocator() == x.get_allocator() is true.
addressof(x) != this is true.
Effects:Inserts the contents of x afterposition, and x becomes empty.
Pointers and references to the moved elements of x now refer to those same elements but as members of *this.
Iterators referring to the moved elements will continue to refer to their elements, but they now behave as iterators into *this, not into x.
void splice_after(const_iterator position, forward_list& x, const_iterator i);void splice_after(const_iterator position, forward_list&& x, const_iterator i);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
The iterator following i is a dereferenceable iterator in x.
get_allocator() == x.get_allocator() is true.
Effects:Inserts the element following i into *this, followingposition, and removes it from x.
The result is unchanged if position == i or position == ++i.
Pointers and references to *++i continue to refer to the same element but as a member of*this.
Iterators to *++i continue to refer to the same element, but now behave as iterators into *this, not into x.
void splice_after(const_iterator position, forward_list& x, const_iterator first, const_iterator last);void splice_after(const_iterator position, forward_list&& x, const_iterator first, const_iterator last);
Preconditions: position is before_begin() or is a dereferenceable iterator in the range [begin(), end()).
(first, last) is a valid range in x, and all iterators in the range (first, last) are dereferenceable.
position is not an iterator in the range (first, last).
get_allocator() == x.get_allocator() is true.
Effects:Inserts elements in the range (first, last) after position and removes the elements from x.
Pointers and references to the moved elements ofx now refer to those same elements but as members of *this.
Iterators referring to the moved elements will continue to refer to their elements, but they now behave as iterators into *this, not into x.
size_type remove(const T& value);template<class Predicate> size_type remove_if(Predicate pred);
Effects:Erases all the elements in the list referred to by a list iterator i for which the following conditions hold: *i == value (for remove()),pred(*i) is true (for remove_if()).
Invalidates only the iterators and references to the erased elements.
Returns:The number of elements erased.
Throws:Nothing unless an exception is thrown by the equality comparison or the predicate.
Complexity:Exactly distance(begin(), end()) applications of the corresponding predicate.
size_type unique();template<class BinaryPredicate> size_type unique(BinaryPredicate pred);
Effects:Erases all but the first element from every consecutive group of equal elements referred to by the iterator i in the range [first + 1, last) for which *i == *(i-1) (for the version with no arguments) or pred(*i,*(i - 1)) (for the version with a predicate argument) holds.
Invalidates only the iterators and references to the erased elements.
Returns:The number of elements erased.
Throws:Nothing unless an exception is thrown by the equality comparison or the predicate.
Complexity:If the range [first, last) is not empty, exactly (last - first) - 1 applications of the corresponding predicate, otherwise no applications of the predicate.
void merge(forward_list& x);void merge(forward_list&& x);template<class Compare> void merge(forward_list& x, Compare comp);template<class Compare> void merge(forward_list&& x, Compare comp);
Preconditions: *this and x are both sorted with respect to the comparator operator< (for the first two overloads) orcomp (for the last two overloads), andget_allocator() == x.get_allocator() is true.
Effects:Merges the two sorted ranges [begin(), end()) and[x.begin(), x.end()).
x is empty after the merge.
If an exception is thrown other than by a comparison there are no effects.
Pointers and references to the moved elements of x now refer to those same elements but as members of *this.
Iterators referring to the moved elements will continue to refer to their elements, but they now behave as iterators into *this, not intox.
Complexity:At most distance(begin(), end()) + distance(x.begin(), x.end()) - 1 comparisons.
void sort();template<class Compare> void sort(Compare comp);
Effects:Sorts the list according to the operator< or the comp function object.
If an exception is thrown, the order of the elements in *this is unspecified.
Does not affect the validity of iterators and references.
Complexity:Approximately comparisons, where N is distance(begin(), end()).
Effects:Reverses the order of the elements in the list.
Does not affect the validity of iterators and references.
22.3.9.7 Erasure [forward.list.erasure]
template<class T, class Allocator, class U> typename forward_list<T, Allocator>::size_type erase(forward_list<T, Allocator>& c, const U& value);
Effects:Equivalent to: return erase_if(c, [&](auto& elem) { return elem == value; });
template<class T, class Allocator, class Predicate> typename forward_list<T, Allocator>::size_type erase_if(forward_list<T, Allocator>& c, Predicate pred);
Effects:Equivalent to: return c.remove_if(pred);