C++ 11 和 C++ 14 中 STL 函数对象的改进?

stl 函数对象经历了重大改进,包括 c++++ 11 中的完美转发和移动语义,以及 c++ 14 中的函数指针封装和通用 lambda。这些改进增强了可用性、效率和灵活性,例如,通用 lambda 简化了排序函数对象的编写,只需使用 std::less{} 即可进行降序排序。

C++ 11 和 C++ 14 中 STL 函数对象的改进?

C++ 11 和 C++ 14 中 STL 函数对象的改进

在 C++ 标准库 (STL) 的发展过程中,函数对象得到了重大改进。这些改进旨在增强可用性、效率和灵活性。

C++ 11 中的改进

  • 完美转发:完美转发允许函数对象接收和转发函数参数,而无需显式类型转换或复制,从而提高了效率。

代码示例:

struct Forwarder {
  template <typename ...Args>
  void operator()(Args&&... args) const {
    std::forward<Args>(args)...; // 完美转发参数
  }
};
登录后复制
  • move 语义:move 语义允许函数对象移动其内部状态,而不是进行复制,从而进一步提高了效率。

代码示例:

struct Mover {
  std::string value;

  Mover(Mover&& other) noexcept
    : value(std::move(other.value)) {
    other.value.clear(); // 移出旧值
  }
};
登录后复制

C++ 14 中的改进

  • 函数指针封装:C++ 14 引入了 std::function 类型,它可以封装函数指针,这使得更轻松地将函数指针作为对象使用。

代码示例:

auto plus = std::function<int(int, int)>([](int a, int b) { return a + b; });
登录后复制
  • 通用 lambda:通用 lambda 允许使用模板指定 lambda 表达式的类型,从而提供了类型安全性和灵活性。

代码示例:

auto sort_by = [](const auto& a, const auto& b) { return a < b; };
登录后复制

实战案例

假设有一个学生成绩的数据结构,现在我们要使用 STL 函数对象对成绩进行排序。

C++ 11 代码:

std::vector<int> grades = {90, 85, 95, 88, 92};

std::sort(grades.begin(), grades.end(),
  [](int a, int b) { return a > b; }); // 降序排序
登录后复制

C++ 14 代码:

std::vector<int> grades = {90, 85, 95, 88, 92};

std::ranges::sort(grades, std::less{}); // 降序排序
登录后复制

正如你所看到的,C++ 14 中引入的通用 lambda 简化了排序函数对象的编写。

以上就是C++ 11 和 C++ 14 中 STL 函数对象的改进?的详细内容,更多请关注小编网其它相关文章!

转载请说明出处 内容投诉内容投诉
南趣百科 » C++ 11 和 C++ 14 中 STL 函数对象的改进?

南趣百科分享生活经验知识,是您实用的生活科普指南。

查看演示 官网购买