为什么 range::sort 返回迭代器?

问题描述

我可以看到 std::sort 返回 void。但是既然 ranges添加到 C++20 标准中,为什么 std::ranges::sort 返回 iteratorcppreference 指定:

返回值

一个等于 last 的迭代器。

  1. 这个选择背后的原因是什么?
  2. void 相比,用例的优势是什么?

解决方法

您不必将结束迭代器传递给 std::ranges 中的算法。您可以改为传递一个哨兵,它类似于迭代器,但它本身不是迭代器(它不能被取消引用或递增)。想一想,如果您想将空终止字符串传递给算法,这可能会有什么用处。

std::ranges::sort 在进行排序时一定要找到序列的结尾。这是有用的信息,因此返回。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...