std::valarray<T>::cshift
Von cppreference.com
| valarray<T> cshift( int count ) const; |
||
Gibt ein neues valarray gleicher Größe zurück, dessen Elemente um count Positionen zirkulär verschoben sind.
Ein nicht-negativer Wert von count verschiebt die Elemente um count Positionen nach links, und ein negativer Wert von count verschiebt die Elemente um -count Positionen nach rechts.
Inhalt |
[bearbeiten] Parameter
| zählt | - | Anzahl der Positionen, um die die Elemente verschoben werden sollen |
[bearbeiten] Rückgabewert
Das resultierende valarray mit zirkulär verschobenen Elementen.
[bearbeiten] Hinweise
Die Funktion kann mit einem anderen Rückgabetyp als std::valarray implementiert werden. In diesem Fall hat der Ersatztyp die folgenden Eigenschaften
- Alle const-Mitgliedsfunktionen von std::valarray sind vorhanden.
- std::valarray, std::slice_array, std::gslice_array, std::mask_array und std::indirect_array können aus dem Ersatztyp konstruiert werden.
- Für jede Funktion, die ein const std::valarray<T>& als Argument nimmt (außer begin() und end())(seit C++11), werden identische Funktionen hinzugefügt, die die Ersatztypen nehmen;
- Für jede Funktion, die zwei Argumente vom Typ const std::valarray<T>& annimmt, werden identische Funktionen hinzugefügt, die jede Kombination aus const std::valarray<T>& und Ersatztypen annehmen.
- Der Rückgabetyp fügt nicht mehr als zwei Ebenen von Template-Verschachtelung über den am tiefsten verschachtelten Argumenttyp hinaus hinzu.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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'; }
Ausgabe
1 2 3 4 5 6 7 8 3 4 5 6 7 8 1 2
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 618 | C++98 | der Ausdruck der verschobenen Elemente enthält eine Division durch Null, wenn size() 0 ist |
beschreibt die neuen Positionen ohne Verwendung von Ausdrücken |
[bearbeiten] Siehe auch
| Null-auffüllende Verschiebung der Elemente des valarray (public member function) |