std::slice
来自 cppreference.cn
定义于头文件 <valarray> |
||
class slice; |
||
std::slice
是选择器类,用于标识 std::valarray 的子集,类似于 BLAS 切片。 std::slice
类型的对象持有三个值:起始索引、步长和子集中值的总数。 std::slice
类型的对象可以用作 valarray 的 operator[] 的索引。
内容 |
[edit] 成员函数
(构造函数) |
构造切片 (公有成员函数) |
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。
复杂度
常数。
[edit] 非成员函数
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()
[edit] 示例
使用 迹 计算函数的简易 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
[edit] 缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 543 | C++98 | 尚不清楚默认构造的切片是否可用 | 它是可用的(作为空子集) |
[edit] 参见
获取/设置 valarray 元素、切片或掩码 (公有成员函数) | |
valarray 的广义切片:起始索引、长度集、步长集 (类) | |
应用切片后 valarray 子集的代理 (类模板) | |
(C++23) |
多维非拥有数组视图 (类模板) |