std::array<T,N>::at
Von cppreference.com
| reference at( size_type pos ); |
(1) | (seit C++11) (constexpr seit C++17) |
| const_reference at( size_type pos ) const; |
(2) | (seit C++11) (constexpr seit C++14) |
Gibt eine Referenz auf das Element an der angegebenen Position pos zurück, mit Bereichsprüfung.
Wenn pos nicht innerhalb des Bereichs des Containers liegt, wird eine Ausnahme vom Typ std::out_of_range ausgelöst.
Inhalt |
[editieren] Parameter
| pos | - | Position des zurückzugebenden Elements |
[editieren] Rückgabewert
Referenz auf das angeforderte Element
[editieren] Ausnahmen
std::out_of_range wenn pos >= size().
[editieren] Komplexität
Konstant.
[editieren] Beispiel
Führen Sie diesen Code aus
#include <chrono> #include <cstddef> #include <iostream> #include <array> #include <stdexcept> int main() { std::array<int, 6> data{1, 2, 4, 5, 5, 6}; // Set element 1 data.at(1) = 88; // Read element 2 std::cout << "Element at index 2 has value " << data.at(2) << '\n'; std::cout << "data size = " << data.size() << '\n'; try { // Try to set an element at random position >= size() auto moon_phase = [] { return std::chrono::system_clock::now().time_since_epoch().count() % 8; }; data.at(data.size() + moon_phase()) = 13; } catch(const std::out_of_range& ex) { std::cout << ex.what() << '\n'; } // Print final values std::cout << "data:"; for (int elem : data) std::cout << ' ' << elem; std::cout << '\n'; }
Mögliche Ausgabe
Element at index 2 has value 4 data size = 6 array::at: __n (which is 8) >= _Nm (which is 6) data: 1 88 4 5 5 6
[editieren] Siehe auch
| Greift auf ein bestimmtes Element zu (public member function) |