Namespaces
Variants

std:: is_corresponding_member

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
Definido en el encabezado <type_traits>
template < class S1, class S2, class M1, class M2 >
constexpr bool is_corresponding_member ( M1 S1 :: * mp, M2 S2 :: * mq ) noexcept ;
(desde C++20)

Determina si mp y mq se refieren a miembros correspondientes en la secuencia inicial común de S1 y S2 . El programa está mal formado si S1 o S2 es un tipo incompleto .

Si S1 o S2 no es un StandardLayoutType , o si M1 o M2 no es un tipo objeto, o si mp o mq es igual a nullptr , el resultado siempre es false .

Contenidos

Parámetros

mp, mq - punteros-a-miembro a detectar

Valor de retorno

true si mp y mq se refieren a miembros correspondientes en la secuencia inicial común de S1 y S2 , de lo contrario false .

Notas

El tipo de una expresión de puntero-a-miembro & S :: m no siempre es M S :: * , donde m es de tipo M , porque m puede ser un miembro heredado de una clase base de S . Los argumentos de plantilla pueden especificarse para evitar resultados potencialmente sorprendentes.

Ejemplo

#include <type_traits>
struct Foo
{
    int x;
    double d;
};
struct Bar
{
    int y;
    double z;
};
struct Baz : Foo, Bar {}; // no es standard-layout
static_assert(
    std::is_same_v<decltype(&Baz::x), int Foo::*> == true &&
    std::is_same_v<decltype(&Baz::y), int Bar::*> == true &&
    std::is_corresponding_member(&Foo::x, &Bar::y) == true &&
    std::is_corresponding_member(&Foo::d, &Bar::z) == true &&
    std::is_corresponding_member(&Baz::x, &Baz::y) == true &&
    std::is_corresponding_member<Baz, Baz, int, int>(&Baz::x, &Baz::y) == false
);
int main() {}

Véase también

verifica si un tipo es un tipo de diseño-estándar
(plantilla de clase)
verifica si dos tipos son layout-compatible
(plantilla de clase)
verifica si un tipo es un puntero a miembro de objeto no estático
(plantilla de clase)