std::valarray<T>::cshift
來自 cppreference.com
valarray<T> cshift( int count ) const; |
||
返回一個大小相同的新 valarray,其元素的位置按 count 元素迴圈移動。
count 的非負值將元素迴圈左移 count 位,而 count 的負值將元素迴圈右移 -count 位。
目錄 |
[編輯] 引數
count | - | 要移動元素的位數 |
[編輯] 返回值
帶有迴圈移動元素的 valarray 結果。
[編輯] 注意
該函式可以使用與 std::valarray 不同的返回型別實現。在這種情況下,替換型別具有以下屬性:
- 提供 std::valarray 的所有 const 成員函式。
- std::valarray、std::slice_array、std::gslice_array、std::mask_array 和 std::indirect_array 可以從替換型別構造。
- 對於每個接受 const std::valarray<T>& 的函式,除了 begin() 和 end()(C++11 起),應新增接受替換型別的相同函式;
- 對於每個接受兩個 const std::valarray<T>& 引數的函式,應新增接受 const std::valarray<T>& 和替換型別的各種組合的相同函式。
- 返回型別不會在最深層巢狀的引數型別之上增加超過兩個模板巢狀級別。
[編輯] 示例
執行此程式碼
#include <iostream> #include <valarray> int main() { std::valarray<int> v{1, 2, 3, 4, 5, 6, 7, 8}; for (auto const& val : v) std::cout << val << ' '; std::cout << '\n'; std::valarray<int> v2 = v.cshift(2); for (auto const& val : v2) std::cout << val << ' '; std::cout << '\n'; }
輸出
1 2 3 4 5 6 7 8 3 4 5 6 7 8 1 2
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 618 | C++98 | 移位元素的表示式 如果 size() 為 0 則包含零除 |
描述新位置 不使用表示式 |
[編輯] 另請參閱
將 valarray 的元素進行零填充移位 (公有成員函式) |