Пространства имён
Варианты
Действия

std::derived_from

Материал из cppreference.com
< cpp‎ | concepts
 
 
 
Определено в заголовочном файле <concepts>
template< class Derived, class Base >

concept derived_from =
  std::is_base_of_v<Base, Derived> &&

  std::is_convertible_v<const volatile Derived*, const volatile Base*>;
(начиная с C++20)

Концепт derived_from<Derived, Base> удовлетворяется тогда и только тогда, когда Base является классовым типом, который является либо Derived, либо открытым и однозначным предком Derived, игнорируя cv-квалификаторы.

Обратите внимание на то, что это поведение отличается от std::is_base_of, когда Base является частным или защищённым предком Derived.

[править] Пример

#include <concepts>
 
class A {};
 
class B: public A {};
 
class C: private A{};
 
int main() {
    // std::derived_from == true только для открытого наследования или
    // точно такого же класса
    static_assert( std::derived_from<B, B> == true );      // тот же класс: true
    static_assert( std::derived_from<int, int> == false ); // тот же примитивный тип: false
    static_assert( std::derived_from<B, A> == true );      // открытое наследование: true
    static_assert( std::derived_from<C, A> == false );     // частное наследование: false
 
    // std::is_base_of == true также для частного наследования
    static_assert( std::is_base_of_v<B, B> == true );      // тот же класс: true
    static_assert( std::is_base_of_v<int, int> == false ); // тот же примитивный тип: false
    static_assert( std::is_base_of_v<A, B> == true );      // открытое наследование: true
    static_assert( std::is_base_of_v<A, C> == true );      // частное наследование: true
}

[править] Смотрите также

проверяет, является ли тип производным от другого типа
(шаблон класса) [править]
проверяет, можно ли преобразовать тип в другой тип
(шаблон класса) [править]