CARVIEW |
Select Language
HTTP/1.1 301 Moved Permanently
Server: nginx
Date: Sat, 19 Jul 2025 16:28:11 GMT
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Connection: keep-alive
Location: /reference/list/list/remove/
HTTP/1.1 200 OK
Server: nginx
Date: Sat, 19 Jul 2025 16:28:12 GMT
Content-Type: text/html; charset=utf-8
Transfer-Encoding: chunked
Connection: keep-alive
ETag: W/"7f72-RLwElQaNeBB3eg1EgCcvHOAWNKA"
Content-Encoding: gzip
Removes from the container all the elements that compare equal to val. This calls the destructor of these objects and reduces the container size by the number of elements removed.
Unlike member function list::erase, which erases elements by their position (using an iterator), this function (list::remove) removes elements by their value.
A similar function, list::remove_if, exists, which allows for a condition other than an equality comparison to determine whether an element is removed.
Output:
All other iterators, pointers and reference keep their validity.
The elements removed are modified. Concurrently accessing or modifying other elements is safe, although iterating through the container is not.
Otherwise, if an exception is thrown, the container is left in a valid state (basic guarantee).
Reference
C library:
- <cassert> (assert.h)
- <cctype> (ctype.h)
- <cerrno> (errno.h)
-
<cfenv> (fenv.h)C++11
- <cfloat> (float.h)
-
<cinttypes> (inttypes.h)C++11
- <ciso646> (iso646.h)
- <climits> (limits.h)
- <clocale> (locale.h)
- <cmath> (math.h)
- <csetjmp> (setjmp.h)
- <csignal> (signal.h)
- <cstdarg> (stdarg.h)
-
<cstdbool> (stdbool.h)C++11
- <cstddef> (stddef.h)
-
<cstdint> (stdint.h)C++11
- <cstdio> (stdio.h)
- <cstdlib> (stdlib.h)
- <cstring> (string.h)
-
<ctgmath> (tgmath.h)C++11
- <ctime> (time.h)
-
<cuchar> (uchar.h)C++11
- <cwchar> (wchar.h)
- <cwctype> (wctype.h)
Containers:
-
<array>C++11
- <deque>
-
<forward_list>C++11
- <list>
- <map>
- <queue>
- <set>
- <stack>
-
<unordered_map>C++11
-
<unordered_set>C++11
- <vector>
-
Input/Output:
Multi-threading:
-
<atomic>C++11
-
<condition_variable>C++11
-
<future>C++11
-
<mutex>C++11
-
<thread>C++11
-
Other:
- <algorithm>
- <bitset>
-
<chrono>C++11
-
<codecvt>C++11
- <complex>
- <exception>
- <functional>
-
<initializer_list>C++11
- <iterator>
- <limits>
- <locale>
- <memory>
- <new>
- <numeric>
-
<random>C++11
-
<ratio>C++11
-
<regex>C++11
- <stdexcept>
- <string>
-
<system_error>C++11
-
<tuple>C++11
-
<type_traits>C++11
-
<typeindex>C++11
- <typeinfo>
- <utility>
- <valarray>
list
- list::~list
- list::list
member functions
- list::assign
- list::back
- list::begin
-
list::cbeginC++11
-
list::cendC++11
- list::clear
-
list::crbeginC++11
-
list::crendC++11
-
list::emplaceC++11
-
list::emplace_backC++11
-
list::emplace_frontC++11
- list::empty
- list::end
- list::erase
- list::front
- list::get_allocator
- list::insert
- list::max_size
- list::merge
- list::operator=
- list::pop_back
- list::pop_front
- list::push_back
- list::push_front
- list::rbegin
- list::remove
- list::remove_if
- list::rend
- list::resize
- list::reverse
- list::size
- list::sort
- list::splice
- list::swap
- list::unique
non-member overloads
public member function
<list>
std::list::remove
void remove (const value_type& val);
Remove elements with specific value
Unlike member function list::erase, which erases elements by their position (using an iterator), this function (list::remove) removes elements by their value.
A similar function, list::remove_if, exists, which allows for a condition other than an equality comparison to determine whether an element is removed.
Parameters
- val
- Value of the elements to be removed.
Member type value_type is the type of the elements in the container, defined in list as an alias of its first template parameter (T).
Return value
noneExample
|
|
Output:
mylist contains: 17 7 14 |
Complexity
Linear in container size (comparisons).Iterator validity
Iterators, pointers and references referring to elements removed by the function are invalidated.All other iterators, pointers and reference keep their validity.
Data races
The container is modified.The elements removed are modified. Concurrently accessing or modifying other elements is safe, although iterating through the container is not.
Exception safety
If the equality comparison between elements is guaranteed to not throw, the function never throws exceptions (no-throw guarantee).Otherwise, if an exception is thrown, the container is left in a valid state (basic guarantee).
See also
- list::remove_if
- Remove elements fulfilling condition (public member function template)
- list::erase
- Erase elements (public member function)
- list::unique
- Remove duplicate values (public member function)
- list::pop_back
- Delete last element (public member function)
- list::pop_front
- Delete first element (public member function)
Home page | Privacy policy
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us