Namespaces
Variants

std::optional<T>:: value

From cppreference.net
Utilities library
constexpr T & value ( ) & ;
constexpr const T & value ( ) const & ;
(1) (depuis C++17)
constexpr T && value ( ) && ;
constexpr const T && value ( ) const && ;
(2) (depuis C++17)

Si * this contient une valeur, retourne une référence à la valeur contenue.

Sinon, lève une exception std::bad_optional_access .

Table des matières

Paramètres

(aucun)

Valeur de retour

Une référence à la valeur contenue.

Exceptions

std::bad_optional_access si * this ne contient pas de valeur.

Notes

L'opérateur de déréférencement operator*() ne vérifie pas si cet optionnel contient une valeur, ce qui peut être plus efficace que value() .

Exemple

#include <iostream>
#include <optional>
int main()
{
    std::optional<int> opt = {};
    try
    {
        [[maybe_unused]] int n = opt.value();
    {
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
    try
    {
        opt.value() = 42;
    }
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
    opt = 43;
    std::cout << *opt << '\n';
    opt.value() = 44;
    std::cout << opt.value() << '\n';
}

Sortie :

bad optional access
bad optional access
43
44

Voir aussi

renvoie la valeur contenue si disponible, une autre valeur sinon
(fonction membre publique)
accède à la valeur contenue
(fonction membre publique)
exception indiquant un accès vérifié à un optional ne contenant pas de valeur
(classe)