Namespaces
Variants

std:: tuple_size <std::complex>

From cppreference.net
Défini dans l'en-tête <complex>
template < class T >

struct tuple_size < std:: complex < T >>

: std:: integral_constant < std:: size_t , 2 > { } ;
(depuis C++26)

La spécialisation partielle de std::tuple_size pour std::complex fournit un moyen à la compilation d'obtenir le nombre de composants d'un complex , qui est toujours 2 , en utilisant la syntaxe de type tuple. Elle est fournie pour la prise en charge de la liaison structurée.

Table des matières

Hérité de std:: integral_constant

Constantes membres

value
[static]
la valeur constante 2
(constante membre publique statique)

Fonctions membres

operator std::size_t
convertit l'objet en std:: size_t , retourne value
(fonction membre publique)
operator()
(C++14)
retourne value
(fonction membre publique)

Types membres

Type Définition
value_type std:: size_t
type std:: integral_constant < std:: size_t , value >

Notes

Macro de test de fonctionnalité Valeur Std Fonctionnalité
__cpp_lib_tuple_like 202311L (C++26) Ajouter le protocole tuple à std::complex

Exemple

#include <complex>
static_assert(std::tuple_size_v<std::complex<float>> == 2);
static_assert([]
{
    using namespace std::literals;
    auto [re, im] = -1.5 + 2.5i;
    return re == -1.5 && im == 2.5;
}());
static_assert([]
{
    using namespace std::literals;
    auto z = std::complex<double>{};
    auto& [re, im] = z;
    re = 1.0;
    im = 2.0;
    return z == 1.0 + 2.0i;
}());
int main() {}

Voir aussi

Structured binding (C++17) lie les noms spécifiés aux sous-objets ou éléments de tuple de l'initialiseur
(C++11)
obtient le nombre d'éléments d'un type de type tuple
(modèle de classe)
obtient le type sous-jacent des nombres réel et imaginaire d'un std::complex
(spécialisation de modèle de classe)
obtient une référence à la partie réelle ou imaginaire d'un std::complex
(modèle de fonction)