C++20 统一容器擦除:std::erase 和 std::erase_if

文章目录

    • [一、`std::erase` 的用法](#一、std::erase 的用法)
      • [1.1 语法](#1.1 语法)
      • [1.2 参数](#1.2 参数)
      • [1.3 返回值](#1.3 返回值)
      • [1.4 示例](#1.4 示例)
    • [二、`std::erase_if` 的用法](#二、std::erase_if 的用法)
      • [2.1 语法](#2.1 语法)
      • [2.2 参数](#2.2 参数)
      • [2.3 返回值](#2.3 返回值)
      • [2.4 示例](#2.4 示例)
    • 三、优势与应用场景
      • [3.1 统一的接口](#3.1 统一的接口)
      • [3.2 简化代码](#3.2 简化代码)
      • [3.3 适用范围广](#3.3 适用范围广)
    • 四、总结

C++20 引入了两个非常实用的函数模板: std::erasestd::erase_if,它们为容器操作提供了更简洁、统一的接口,极大地简化了容器元素的删除操作。

一、std::erase 的用法

std::erase 用于从容器中删除所有与指定值匹配的元素。它适用于所有标准容器,如 std::vectorstd::liststd::map 等。

1.1 语法

cpp 复制代码
template<class Container, class T>
constexpr auto erase(Container& c, const T& value);

1.2 参数

  • c:要操作的容器。
  • value:要删除的元素值。

1.3 返回值

返回删除的元素数量。

1.4 示例

cpp 复制代码
#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5, 3, 6};
    auto erased_count = std::erase(vec, 3); // 删除所有值为3的元素
    std::cout << "Erased " << erased_count << " elements.\n";
    for (int i : vec) {
        std::cout << i << " ";
    }
    return 0;
}

输出:

复制代码
Erased 2 elements.
1 2 4 5 6

二、std::erase_if 的用法

std::erase_if 用于从容器中删除满足特定条件的元素。

2.1 语法

cpp 复制代码
template<class Container, class Predicate>
constexpr auto erase_if(Container& c, Predicate pred);

2.2 参数

  • c:要操作的容器。
  • pred:谓词函数,返回 true 表示该元素应被删除。

2.3 返回值

返回删除的元素数量。

2.4 示例

cpp 复制代码
#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5, 6};
    auto erased_count = std::erase_if(vec, [](int x) { return x % 2 == 0; }); // 删除所有偶数
    std::cout << "Erased " << erased_count << " elements.\n";
    for (int i : vec) {
        std::cout << i << " ";
    }
    return 0;
}

输出:

复制代码
Erased 3 elements.
1 3 5

三、优势与应用场景

3.1 统一的接口

std::erasestd::erase_if 提供了统一的接口,使得对不同容器的删除操作更加一致。这减少了开发者对不同容器成员函数的依赖,降低了学习成本。

3.2 简化代码

使用 std::erasestd::erase_if 可以避免手动使用迭代器进行删除操作,简化了代码。例如,std::erase_if 可以替代 std::remove_iferase 的组合,减少了代码量。

3.3 适用范围广

这两个函数适用于所有标准容器,包括 std::vectorstd::liststd::map 等。这使得它们在处理不同类型容器时更加通用。

四、总结

C++20 的 std::erasestd::erase_if 为容器操作提供了更简洁、统一的接口。它们不仅简化了代码,还减少了开发者对不同容器成员函数的依赖。在实际开发中,这两个函数可以显著提高代码的可读性和可维护性。

相关推荐
charlie11451419110 天前
精读C++20设计模式:行为型设计模式:中介者模式
c++·学习·设计模式·c++20·中介者模式
charlie11451419112 天前
理解C++20的革命特性——协程引用之——利用协程做一个迷你的Echo Server
网络·学习·socket·c++20·协程·epoll·raii
charlie11451419112 天前
理解C++20的革命特性——协程支持2:编写简单的协程调度器
c++·学习·算法·设计模式·c++20·协程·调度器
charlie11451419113 天前
精读C++20设计模式——结构型设计模式:外观模式
c++·学习·设计模式·c++20·外观模式
渡我白衣13 天前
C++ :std::bind 还能用吗?它和 Lambda 有什么区别?
开发语言·c++·c++20
charlie11451419114 天前
理解C++20的革命特性——协程支持1
c++·学习·c++20·协程·语言特性·调度·现代c++
渡我白衣14 天前
C++20 协程:在 AI 推理引擎中的深度应用
大数据·人工智能·c++20
charlie11451419114 天前
精读 C++20 设计模式:行为型设计模式 — 访问者模式
c++·学习·设计模式·访问者模式·c++20
charlie11451419115 天前
精读C++20设计模式——行为型设计模式:命令模式
c++·学习·设计模式·程序设计·命令模式·c++20
charlie11451419116 天前
精读C++20设计模式——行为型设计模式:迭代器模式
c++·学习·设计模式·迭代器模式·c++20