std:: get_if (std::variant)
|
Défini dans l'en-tête
<variant>
|
||
| (1) | (depuis C++17) | |
|
template
<
std::
size_t
I,
class
...
Types
>
constexpr
std::
add_pointer_t
<
std::
variant_alternative_t
<
I,
std::
variant
<
Types...
>>>
|
||
|
template
<
std::
size_t
I,
class
...
Types
>
constexpr
std::
add_pointer_t
<
const
std::
variant_alternative_t
<
I,
std::
variant
<
Types...
>>>
|
||
| (2) | (depuis C++17) | |
|
template
<
class
T,
class
...
Types
>
constexpr
std::
add_pointer_t
<
T
>
|
||
|
template
<
class
T,
class
...
Types
>
constexpr
std::
add_pointer_t
<
const
T
>
|
||
I
n'est pas un index valide dans la variante.
I
étant l'index de base zéro de
T
dans
Types...
. L'appel est mal formé si
T
n'est pas un élément unique de
Types...
.
Table des matières |
Paramètres du modèle
| I | - | index à rechercher |
| Type | - | type unique à rechercher |
Paramètres
| pv | - | pointeur vers une variante |
Valeur de retour
Pointeur vers la valeur stockée dans la variante pointée ou pointeur nul en cas d'erreur.
Exemple
#include <iostream> #include <variant> int main() { auto check_value = [](const std::variant<int, float>& v) { if (const int* pval = std::get_if<int>(&v)) std::cout << "variant value: " << *pval << '\n'; else std::cout << "failed to get value!" << '\n'; }; std::variant<int, float> v{12}, w{3.f}; check_value(v); check_value(w); }
Sortie :
variant value: 12 failed to get value!
Voir aussi
|
(C++17)
|
lit la valeur du variant selon l'index ou le type (si le type est unique), lance une exception en cas d'erreur
(modèle de fonction) |