Namensräume
Varianten
Aktionen

std::optional<T>::begin

Von cppreference.com
< cpp‎ | utility‎ | optional
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
constexpr iterator begin() noexcept;
(seit C++26)
constexpr const_iterator begin() const noexcept;
(seit C++26)

Wenn *this einen Wert enthält, wird ein Iterator auf den enthaltenen Wert zurückgegeben. Andernfalls ein Iterator, der auf das Ende verweist.

range-begin-end.svg

Inhalt

[bearbeiten] Parameter

(keine)

[bearbeiten] Rückgabewert

Iterator auf den enthaltenen Wert, wenn has_value() true ist. Andernfalls ein Iterator, der auf das Ende verweist.

[bearbeiten] Komplexität

Konstant.

[bearbeiten] Anmerkungen

Feature-Test-Makro Wert Std Feature
__cpp_lib_optional_range_support 202406L (C++26) Bereichsunterstützung für std::optional

[bearbeiten] Beispiel

#include <optional>
#include <print>
#include <vector>
 
int main()
{
    constexpr std::optional<int> none = std::nullopt;
    constexpr std::optional<int> some = 42;
 
    static_assert(none.begin() == none.end());
    static_assert(some.begin() != some.end());
 
    // ranged-for loop support
    for (int i : none)
        std::println("'none' has a value of {}", i);
 
    for (int i : some)
        std::println("'some' has a value of {}", i);
 
    std::optional<std::vector<int>> many({0, 1, 2});
    for (const auto& v : many)
        std::println("'many' has a value of {}", v);
}

Ausgabe

'some' has a value of 42
'many' has a value of [0, 1, 2]

[bearbeiten] Siehe auch

(C++26)
gibt einen Iterator zum Ende zurück
(public member function) [bearbeiten]