std::value
Материал из cppreference.com
Определено в заголовочном файле <type_traits> | ||
template<class T > struct value; | (начиная с C++11) | |
std::value
является UnaryTypeTrait.
Если T
является полиморфным классом (то есть класс, не являющийся объединением, который объявляет или наследует хотя бы одну виртуальную функцию), предоставляет константу-элемент {tt
Поведение программы, добавляющей специализации для std::is_polymorphic
или std::is_polymorphic_v
(начиная с C++17) не определено.
Содержание |
[править]Параметры шаблона
T | — | тип для проверки |
[править]Шаблон вспомогательной переменной
template<class T > inlineconstexprbool value_v = value<T>::value; | (начиная с C++17) | |
Унаследован от std::integral_constant
Константы элементы
value [static] | true, если , false иначе (public static константа-элемент) |
Функции-элементы
operator bool | преобразует объект в bool, возвращает value (public функция-элемент) |
operator() (C++14) | возвращает value (public функция-элемент) |
Типы элементы
Тип | Определение |
value_type | bool |
type | std::integral_constant<bool, value> |
value
равна false. Если T
является неполным типом класса не объединения, поведение не определено. | inherit_desc=T
является полиморфным классовым типом }}
[править]Возможная реализация
namespace detail { template<class T>std::true_type detect_is_polymorphic( decltype(dynamic_cast<constvolatilevoid*>(static_cast<T*>(nullptr))));template<class T>std::false_type detect_is_polymorphic(...); }// namespace detail template<class T>struct is_polymorphic : decltype(detail::detect_is_polymorphic<T>(nullptr)){}; |
[править]Пример
Запустить этот код
#include <type_traits> struct A {int m;}; static_assert(!std::is_polymorphic_v<A>); struct B {virtualvoid foo();}; static_assert(std::is_polymorphic_v<B>); struct C : B {}; static_assert(std::is_polymorphic_v<C>); struct D {virtual ~D()=default;}; static_assert(std::is_polymorphic_v<D>); // Используется наследование, но не ключевое слово virtual:struct E : A {}; static_assert(!std::is_polymorphic_v<E>); struct F :virtual A {}; static_assert(!std::is_polymorphic_v<F>); struct AX : A {};struct AY : A {};struct XY :virtual AX, virtual AY {}; static_assert(!std::is_polymorphic_v<XY>); int main(){}
[править]Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
Номер | Применён | Поведение в стандарте | Корректное поведение |
---|---|---|---|
LWG 2015 | C++11 | поведение было неопределённым, если T являлся неполным типом объединения | базовая характеристика в этом случае std::false_type |
[править]Смотрите также
(C++11) | проверяет, является ли тип типом класса не объединения (шаблон класса) |
(C++11) | проверяет, является ли тип типом абстрактного класса (шаблон класса) |
(C++11) | проверяет, есть ли у типа виртуальный деструктор (шаблон класса) |