std::slice
来自 cppreference.com
定义在头文件 <valarray> 中 |
||
class slice; |
||
std::slice
是一个选择器类,它类似于 BLAS 切片,用于标识 std::valarray 的子集。std::slice
类型的对象保存三个值:起始索引、步长和子集中值的总数。std::slice
类型的对象可以用作 valarray 的 operator[] 的索引。
内容 |
[编辑] 成员函数
(构造函数) |
构造一个切片 (公有成员函数) |
startsizestride |
返回切片的参数 (公有成员函数) |
std::slice::slice
slice() |
(1) | |
slice( std::size_t start, std::size_t size, std::size_t stride ); |
(2) | |
slice( const slice& other ); |
(3) | |
构造一个新的切片。
1) 默认构造函数。等效于 slice(0, 0, 0)。此构造函数仅存在是为了允许构造切片数组。
2) 用参数 start、size、stride 构造一个新的切片。此切片将引用 size 个元素,每个元素的位置为
start + 0 * stride
start + 1 * stride
...
start + (size - 1) * stride
3) 构造 other 的副本。
参数
start | - | 第一个元素的位置 |
size | - | 切片中的元素数量 |
stride | - | 切片中连续元素之间的位置数量 |
other | - | 要复制的另一个切片 |
std::slice::start, size, stride
std::size_t start() const; |
(1) | |
std::size_t size() const; |
(2) | |
std::size_t stride() const; |
(3) | |
返回构造切片时传递的参数 - 分别为 start、size 和 stride。
参数
(无)
返回值
切片的参数 - 分别为 start、size 和 stride。
复杂度
常数。
[编辑] 非成员函数
operator==(std::slice) (C++20) |
检查两个切片是否相等 (函数) |
operator==(std::slice)
friend bool operator==( const slice& lhs, const slice& rhs ); |
(自 C++20 起) | |
检查 lhs 和 rhs 的参数 - start、size 和 stride 是否分别相等。
此函数对普通的 非限定 或 限定查找 不可見,只能在 std::slice 是参数的关联类时,通过 依赖于参数的查找 找到。
!=
运算符从 operator==
合成。
参数
lhs, rhs | - | 要比较的切片 |
返回值
lhs.start() == rhs.start() && lhs.size() == rhs.size() && lhs.stride() == rhs.stride()
[编辑] 示例
使用 valarray 支持的矩阵类,带有计算 迹 的函数。
运行此代码
#include <iostream> #include <valarray> class Matrix { std::valarray<int> data; int dim; public: Matrix(int r, int c) : data(r*c), dim(c) {} int& operator()(int r, int c) { return data[r * dim + c]; } int trace() const { return data[std::slice(0, dim, dim + 1)].sum(); } }; int main() { Matrix m(3, 3); int n = 0; for (int r = 0; r < 3; ++r) for (int c = 0; c < 3; ++c) m(r, c) = ++n; std::cout << "Trace of the matrix (1,2,3) (4,5,6) (7,8,9) is " << m.trace() << '\n'; }
输出
Trace of the matrix (1,2,3) (4,5,6) (7,8,9) is 15
[编辑] 缺陷报告
以下行为变更缺陷报告被追溯应用于之前发布的 C++ 标准。
DR | 应用于 | 已发布的行为 | 正确的行为 |
---|---|---|---|
LWG 543 | C++98 | 不清楚默认构造的切片是否可用 | 它可用(作为空子集) |
[编辑] 参见
获取/设置 valarray 元素、切片或掩码 (公有成员函数) | |
valarray 的广义切片:起始索引、长度集、步长集 (类) | |
在应用切片后,对 valarray 子集的代理 (类模板) |