Introduction to Forward List in C++ STL and Important Functions

Nitish Singh
3 min readJun 14, 2023

--

Looking for a container class that can keep up with the demands of modern programming? The forward list in the C++ STL is here to answer the call! With its efficient insertion, removal, and sorting operations, this container class is a must-have for anyone looking to streamline their code. Its singly linked list structure means that it’s perfect for scenarios where forward traversal is key, such as hashing and graph representation. And thanks to its reduced storage space for each element, you won’t have to worry about bloated memory usage. Just remember that it doesn’t support backward traversal or direct access to individual elements. So, if you want to stay ahead of the curve and optimize your data structures, give the forward list a try!

Image may be subject to copyright

In this article, we will explore the operations and functions available for working with forward lists in C++.

  1. assign(): The assign() function is used to assign values to the forward list. It has two variants:
    assign(n, value) assigns the value to the forward list, repeating it 'n' times.
    assign(begin, end) assigns values from another list, defined by the range [begin, end), to the forward list.
  2. push_front(): The push_front() function is used to insert an element at the beginning of the forward list. The element is copied to the space before the first element in the container, increasing the list's size by 1.
  3. emplace_front(): The emplace_front() function is similar to push_front(), but it creates the element directly at the memory location before the first element of the forward list, without any copying operation.
  4. pop_front(): The pop_front() function deletes the first element of the forward list.
  5. insert_after(): The insert_after() function allows us to insert elements at any position in the forward list. It takes an iterator pointing to the desired position and copies the provided arguments there.
  6. emplace_after(): The emplace_after() function is similar to insert_after(), but it constructs the element directly at the desired position without any copying operation.
  7. erase_after(): The erase_after() function is used to erase elements from a specific position in the forward list. It has two variants: erase_after(pos) and erase_after(begin, end), which remove elements after the specified position(s).
  8. remove(): The remove() function removes all occurrences of a particular element from the forward list. It removes elements that are equal to the provided value.
  9. remove_if(): The remove_if() function removes elements from the forward list based on a specified condition. It removes elements for which the provided predicate returns true.
  10. clear(): The clear() function deletes all the elements from the forward list, leaving it empty.
  11. splice_after(): The splice_after() function transfers elements from one forward list to another. It allows merging elements from one list into another at a specified position.

Additional Methods of forward list:

  • front(): Returns a reference to the first element of the forward list.
  • begin(): Returns an iterator pointing to the first element of the forward list.
  • end(): Returns an iterator pointing to the last element of the forward list.
  • cbegin(): Returns a constant iterator pointing to the first element of the forward list.
  • cend(): Returns a constant iterator pointing to the past-the-last element of the forward list.
  • before_begin(): Returns an iterator that points to the position before the first element of the forward list.
  • cbefore_begin(): Returns a constant iterator pointing to the position before the first element of the forward list.
  • max_size(): Returns the maximum number of elements that the forward list can hold.
  • resize(): Changes the size of the forward list.
  • unique(): Removes all consecutive duplicate elements from the forward list using a binary predicate for comparison.
  • reverse(): Reverses the order of the elements in the forward list.

Conclusion

The forward list in C++ STL provides a powerful and efficient implementation of a singly linked list. It offers several functions for manipulating and working with the elements in the list, such as inserting, removing, and merging. The forward list is especially suitable when forward traversal is the primary requirement, and it finds applications in various scenarios such as hashing and graph representations. By understanding the available functions and methods, developers can leverage the capabilities of forward lists to efficiently manage and process data in their C++ programs.

If you are interested in understanding the implementation of the forward list in C++, I recommend referring to the following link.

Please follow the provided link if you would like to read more information about singly linked lists.

--

--

Nitish Singh
Nitish Singh

Written by Nitish Singh

Passionate about empowering devs with practical tips, using modern C++ as the tool, and up-to-date knowledge. Join me on Medium for engaging articles.

Responses (1)