范围扩展
来自cppreference.com
< cpp | experimental
C++ 范围扩展 (Extensions for Ranges) , ISO/IEC TS 21425:2017 指定对核心语言的一个修改,并为 C++ 标准库定义列于此页面的新组件。
范围 TS 基于概念 TS 所修改的 C++14 标准。
核心语言更改
范围 TS 修改基于范围的 for 循环规定,以容许不同类型的 begin 和 end 迭代器。此更改容许使用哨位,并且已存在于 C++17 。
概念
核心语言概念 | |
定义于命名空间
std::experimental::ranges | |
指定类型与另一类型相同 (概念) | |
指定该类型从另一类型派生 (概念) | |
指定类型能隐式转换成另一类型 (概念) | |
指定两个类型共有一个公共引用类型 (概念) | |
指定两个类型共有一个公共类型 (概念) | |
指定类型为整型类型 (概念) | |
指定类型为有符号的整型类型 (概念) | |
指定类型为无符号的整型类型 (概念) | |
指定类型可从另一类型赋值 (概念) | |
指定一个类型能进行交换,或两个类型能彼此交换 (概念) | |
比较概念 | |
定义于命名空间
std::experimental::ranges | |
指定类型能用于布尔语境 (概念) | |
指定两个类型能用运算符 == 和 != 比较相等性 (概念) | |
指定运算符 == 是等价关系 (概念) | |
指定该类型上的比较运算符产出全序 (概念) | |
对象概念 | |
定义于命名空间
std::experimental::ranges | |
指定该类型对象能被销毁,且能用一元 & 取其地址 (概念) | |
指定该类型的变量能从一组实参类型进行构造,或绑定到一组实参类型 (概念) | |
指定该类型对象能默认构造 (概念) | |
指定该类型的对象能移动构造 (概念) | |
指定该类型对象能复制构造及移动构造 (概念) | |
指定该类型的对象能被移动和交换 (概念) | |
指定该类型对象能被复制、移动和交换 (概念) | |
指定类型的对象能被复制、移动、交换及默认构造 (概念) | |
指定类型为正则,即为 Semiregular 且为 EqualityComparable (概念) | |
可调用概念 | |
定义于命名空间
std::experimental::ranges | |
指定可调用类型能以给定的一组实参调用 (概念) | |
指定可调用类型是布尔谓词 (概念) | |
指定可调用类型为二元关系 (概念) | |
指定一种 Relation 施加严格弱序 (概念) | |
随机数生成器概念 | |
定义于头文件
<experimental/ranges/random> | |
定义于命名空间
std::experimental::ranges | |
指定类型具备作为均匀随机数生成器的资格 (概念) |
通用工具
工具组件 | |
定义于命名空间
std::experimental::ranges | |
交换两个对象的值 (定制点对象) | |
以新值替换实参并返回其先前的值 (函数模板) | |
函数对象 | |
定义于命名空间
std::experimental::ranges | |
以给定实参调用可调用 (Callable) 对象 (函数模板) | |
实现 x == y 的函数对象 (类模板) | |
实现 x != y 的函数对象 (类模板) | |
实现 x > y 的函数对象 (类模板) | |
实现 x < y 的函数对象 (类模板) | |
实现 x >= y 的函数对象 (类模板) | |
实现 x <= y 的函数对象 (类模板) | |
返回其(未改变的)实参的函数对象 (类) | |
元编程与类型特性 | |
定义于命名空间
std::experimental::ranges | |
检查一个类型的对象是否能与相同或不同类型的对象交换 (类模板) | |
确定类型集合的公共引用类型 (类模板) | |
确定类型集合的公共类型 (类模板) | |
有标签的 pair 与 tuple | |
定义于命名空间
std::experimental::ranges | |
指定类型为标签说明符 (概念) | |
指定类型表示一个标签说明符及其元素类型 (概念) | |
为元组式类型增加具名访问器 (类模板) | |
有标签 std::pair 的别名模版 (别名模板) | |
用于创建 tagged_pair 的便利函数 (函数模板) | |
定义于头文件
<experimental/ranges/tuple> | |
有标签 std::tuple 的别名模版 (别名模板) | |
用于创建 tagged_tuple 的便利函数 (函数模板) | |
定义于命名空间
std::experimental::ranges::tag | |
用于 ranges::tagged 的标签说明符 (类) |
迭代器
迭代器相关概念 | |
定义于命名空间
std::experimental::ranges | |
迭代器概念 | |
指定类型通过应用运算符 * 可读 (概念) | |
指定可向迭代器所引用的对象写入值 (概念) | |
指定 Semiregular 类型能以前后自增运算符自增 (概念) | |
指定 WeaklyIncrementable 类型上的自增操作保持相等性,而且该类型 EqualityComparable (概念) | |
指定该类型对象能自增并解引用 (概念) | |
指定类型的对象是 Iterator 类型的哨位 (概念) | |
指定能应用 - 运算符到迭代器和哨位,以在常数时间计算其差 (概念) | |
指定类型为输入迭代器,即能读其所引用值,且它能前后自增 (概念) | |
指定类型为给定值类型的输出迭代器,即能把该类型的值写入它,且它能前后自增 (概念) | |
指定 InputIterator 为向前迭代器,支持相等比较和多趟 (概念) | |
指定 ForwardIterator 为双向迭代器,支持向后移动 (概念) | |
指定 BidirectionalIterator 为随机访问迭代器,支持常数时间前进和下标访问 (概念) | |
间接可调用概念 | |
指定可调用对象能以解引用一个 Readable 类型的结果调用 (概念) | |
指定可调用对象,以解引用某个 Readable 类型的结果调用时,满足 Predicate (概念) | |
指定可调用对象以解引用某些 Readable 类型的结果调用时,满足 Relation (概念) | |
指定可调用对象,以解引用某些 Readable 类型的结果调用时,满足 StrictWeakOrder (概念) | |
常用算法要求 | |
指定值可从 Readable 类型移动到 Writable 类型 (概念) | |
指定类型可从 Readable 类型移动到 Writable 类型,且移动可以通过中间对象进行 (概念) | |
指定值可从 Readable 类型复制到 Writable 类型 (概念) | |
指定值可从 Readable 类型复制到 Writable 类型,且该复制可能通过中间对象进行 (概念) | |
指定两个 Readable 类型所引用的值可交换 (概念) | |
指定两个 Readable 类型所引用的值能比较 (概念) | |
指定原位重排元素的算法的公共要求 (概念) | |
指定算法的要求,该算法需要通过复制元素归并已排序序列到输出序列 (概念) | |
指定重排元素为有序序列的算法的公共要求 (概念) | |
概念工具 | |
计算在某 Readable 类型集合的解引用结果上调用可调用对象的结果 (类模板) | |
用于指定接受投影的算法上的制约的帮助模板 (类模板) | |
迭代器原语 | |
迭代器工具 | |
定义于命名空间
std::experimental::ranges | |
转型解引用对象的结果为其所关联的右值引用类型 (定制点对象) | |
交换两个可解引用对象所引用的值 (定制点对象) | |
迭代器特性 | |
定义于命名空间
std::experimental::ranges | |
获得 WeaklyIncrementable 类型的差类型 (类模板) | |
获得 Readable 类型的值类型 (类模板) | |
获得输入迭代器类型的迭代器类别 (类模板) | |
汇集迭代器的关联类型的兼容性特性类 (别名模板) | |
获得可解引用对象的关联引用类型 (别名模板) | |
迭代器类别标签 | |
定义于命名空间
std::experimental::ranges | |
用于指示迭代器类别的空类 (类) | |
std::iterator_traits 特化 | |
定义于命名空间
std | |
为范围 TS 迭代器特化 std::iterator_traits (类模板特化) | |
迭代器操作 | |
定义于命名空间
std::experimental::ranges | |
令迭代器前进给定的距离 (函数模板) | |
返回迭代器和哨位之间的距离,或范围起始和结尾间的距离 (函数模板) | |
自增迭代器 (函数模板) | |
自减迭代器 (函数模板) | |
迭代器适配器 | |
定义于命名空间
std::experimental::ranges | |
用于逆序遍历的迭代器适配器 (类模板) | |
用于在容器尾插入的迭代器适配器 (类模板) | |
用于在容器首插入的迭代器适配器 (类模板) | |
用于插入元素到容器中的迭代器适配器 (类模板) | |
解引用为右值引用的迭代器适配器 (类模板) | |
为 move_iterator 所用的哨位适配器 (类模板) | |
将迭代器-哨位对适配成公共迭代器类型,以用于遗留算法 (类模板) | |
保持距起始位置距离踪迹的迭代器适配器 (类模板) | |
知晓其范围的迭代器类型所用的空哨位类型 (类) | |
可能悬垂的迭代器的包装器 (类模板) | |
以 dangling 包装右值范围的迭代器类型的别名模版 (别名模板) | |
用于与任何迭代器一同指示无限范围的哨位类型 (类) | |
流迭代器 | |
定义于命名空间
std::experimental::ranges | |
从 std::basic_istream 读取的输入迭代器 (类模板) | |
写入 std::basic_ostream 的输出迭代器 (类模板) | |
从 std::basic_streambuf 读取的输入迭代器 (类模板) | |
写入 std::basic_streambuf 的输出迭代器 (类模板) |
范围
定义于头文件
<experimental/ranges/range> | |
范围概念 | |
指定类型为范围,即它提供 begin 迭代器和 end 哨位 (概念) | |
指定范围以常数时间知晓其大小 (概念) | |
指定范围为视图,即它拥有常数时间的复制/移动/赋值 (概念) | |
指定范围拥有等同的迭代器和哨位类型 (概念) | |
指定范围的迭代器满足 InputIterator (概念) | |
指定范围的迭代器满足 OutputIterator (概念) | |
指定范围的迭代器满足 ForwardIterator (概念) | |
指定范围的迭代器满足 BidirectionalIterator (概念) | |
指定范围的迭代器满足 RandomAccessIterator (概念) | |
范围访问 | |
定义于命名空间
std::experimental::ranges | |
返回指向范围起始的迭代器 (定制点对象) | |
返回指向范围末尾的迭代器 (定制点对象) | |
获得指向范围的逆向迭代器 (定制点对象) | |
获得指向范围的逆向尾迭代器 (定制点对象) | |
范围原语 | |
定义于命名空间
std::experimental::ranges | |
获得能在常数时间计算大小的范围的大小 (定制点对象) | |
检查范围是否为空 (定制点对象) | |
获得指向连续范围起始的指针 (定制点对象) | |
获得范围的迭代器类型与哨位类型 (别名模板) |
算法
不修改序列的操作 | |
定义于命名空间
std::experimental::ranges | |
检查谓词是否对范围中所有、任一或无元素为 true (函数模板) | |
应用函数到元素范围 (函数模板) | |
返回满足特定判别标准的元素数 (函数模板) | |
寻找两个范围出现不同的首个位置 (函数模板) | |
确定元素的二个集合是否相同 (函数模板) | |
当一个范围按字典顺序小于另一个范围时,返回 true (函数模板) | |
寻找首个满足特定判别标准的元素 (函数模板) | |
在特定范围中寻找最后出现的元素序列 (函数模板) | |
搜索元素集中的任何元素 (函数模板) | |
寻找头两个相等(或满足给定谓词)的相邻项 (函数模板) | |
搜索一个元素范围 (函数模板) | |
在范围中搜索一定量的某个元素的连续副本 (函数模板) | |
修改序列的操作 | |
定义于命名空间
std::experimental::ranges | |
将某一范围的元素复制到一个新的位置 (函数模板) | |
将一定数目的元素复制到一个新的位置 (函数模板) | |
按从后往前的顺序复制一个范围内的元素 (函数模板) | |
将某一范围的元素移动到一个新的位置 (函数模板) | |
按从后往前的顺序移动某一范围的元素到新的位置 (函数模板) | |
将一个特定值赋值给一个元素范围 (函数模板) | |
将一个值赋值给一定数量的元素 (函数模板) | |
应用一个函数到元素范围 (函数模板) | |
保存函数结果于一个范围中 (函数模板) | |
保存 N 次应用一个函数的结果 (函数模板) | |
移除满足特定判别标准的元素 (函数模板) | |
复制元素范围,忽略满足特定判别标准的元素 (函数模板) | |
将所有满足特定判别标准的值替换为另一值 (函数模板) | |
复制范围,以另一值替换满足特定判别标准的元素 (函数模板) | |
交换两个元素范围 (函数模板) | |
逆转范围中的元素顺序 (函数模板) | |
创建一个范围的逆向副本 (函数模板) | |
旋转范围中的元素顺序 (函数模板) | |
复制并旋转元素范围 (函数模板) | |
随机重排范围中的元素 (函数模板) | |
移除范围中连续的重复元素 (函数模板) | |
创建某范围的不含连续重复元素的副本 (函数模板) | |
划分操作 | |
定义于命名空间
std::experimental::ranges | |
判断范围是否已按给定的谓词划分 (函数模板) | |
将范围中的元素分为两组 (函数模板) | |
复制一个范围,将各元素分为两组 (函数模板) | |
划分元素到两个组中,同时保持其相对顺序 (函数模板) | |
定位已划分范围的划分点 (函数模板) | |
排序操作 | |
定义于命名空间
std::experimental::ranges | |
检查范围是否以升序排序 (函数模板) | |
寻找最大已排序子范围 (函数模板) | |
将范围按升序排序 (函数模板) | |
排序一个范围的前 N 个元素 (函数模板) | |
对范围内的元素进行复制并部分排序 (函数模板) | |
将范围内的元素排序,同时保持相等的元素之间的顺序 (函数模板) | |
将给定的范围部分排序,确保其按给定元素划分 (函数模板) | |
二分搜索操作(在已排序范围上) | |
定义于命名空间
std::experimental::ranges | |
返回指向首个不小于给定值的元素的迭代器 (函数模板) | |
返回指向首个大于固定值的元素的迭代器 (函数模板) | |
确定元素是否存在于固定范围中 (函数模板) | |
返回匹配特定关键的元素范围 (函数模板) | |
集合操作(在已排序范围上) | |
定义于命名空间
std::experimental::ranges | |
归并两个已排序范围 (函数模板) | |
就地归并两个已排序范围 (函数模板) | |
若一个集合是另一个的子集则返回 true (函数模板) | |
计算两个集合的差集 (函数模板) | |
计算两个集合的交集 (函数模板) | |
计算两个集合的对称差 (函数模板) | |
计算两个集合的并集 (函数模板) | |
堆操作 | |
定义于命名空间
std::experimental::ranges | |
检查给定范围是否为一个最大堆 (函数模板) | |
寻找作为最大堆的最大子范围 (函数模板) | |
从元素范围中创建出最大堆 (函数模板) | |
添加元素到最大堆 (函数模板) | |
从最大堆移除最大元素 (函数模板) | |
将最大堆转化成以升序排序的元素范围 (函数模板) | |
最小/最大操作 | |
定义于命名空间
std::experimental::ranges | |
返回给定值的较大者 (函数模板) | |
返回范围中的最大元素 (函数模板) | |
返回给定值的较小者 (函数模板) | |
返回范围中的最小元素 (函数模板) | |
返回二个元素的较小和较大者 (函数模板) | |
返回范围中的最小和最大元素 (函数模板) | |
排列操作 | |
定义于命名空间
std::experimental::ranges | |
判断一个序列是否为另一个序列的排列 (函数模板) | |
产生某个元素范围的按字典顺序的下一个较大的排列 (函数模板) | |
产生某个元素范围的按字典顺序的下一个较小的排列 (函数模板) |