C++官网参考链接:https://cplusplus.com/reference/forward_list/forward_list/remove/
公有成员函数
<forward_list>
std::forward_list::remove
void remove (const value_type& val);
删除具有特定值的元素
从容器中删除所有比较值等于val的元素。这将调用这些对象的析构函数,并根据删除的元素数量减少容器的大小。
与成员函数forward_list::erase_after(使用iterator)按位置删除元素不同,这个函数按值删除元素。
还有一个类似的函数forward_list::remove_if,它允许使用除相等比较之外的条件来确定是否删除某个元素。
形参
val
要删除的元素的值。
成员类型value_type是容器中元素的类型,在forward_list中定义为其第一个模板形参(T)的别名。
返回值
没有返回值。
用例
// remove from forward_list
#include <iostream>
#include <forward_list>
int main ()
{
std::forward_list<int> mylist = {10, 20, 30, 40, 30, 20, 10};
mylist.remove(20);
std::cout << "mylist contains:";
for (int& x: mylist) std::cout << ' ' << x;
std::cout << '\n';
return 0;
}
输出:
复杂度
容器大小(比较)中的线性。
iterator的有效性
指向被函数删除的元素的iterator、指针和reference将失效。
所有其它iterator、指针和reference保持它们的有效性。
数据竞争
完成容器的修改。
删除的元素被修改。同时访问或修改其他元素是安全的,但遍历容器就不安全了。
异常安全
如果保证元素之间的相等比较不会抛出,则函数永远不会抛出异常(无抛出保证)。
否则,如果抛出异常,容器将保持有效状态(基本保证)。