为什么 ranges::sort return 是迭代器?

Why does ranges::sort return an iterator?

我可以看到 std::sort returns void。但是既然 ranges 已经添加到 C++20 标准中,为什么 std::ranges::sort return 和 iterator 呢? cppreference 指定:

Return value

An iterator equal to last.

  1. 该选择背后的理由是什么?
  2. void 相比,用例优势是什么?

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

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