std::value
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct value; |
(начиная с C++11) | |
std::value является UnaryTypeTrait.
Если T является полиморфным классом (то есть класс, не являющийся объединением, который объявляет или наследует хотя бы одну виртуальную функцию), предоставляет константу-элемент {tt
Поведение программы, добавляющей специализации для std::is_polymorphic или std::is_polymorphic_v (начиная с C++17) не определено.
Параметры шаблона
| T | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline constexpr bool 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>
|
, равную true. Для любого другого типа value равна false.
Если T является неполным типом класса не объединения, поведение не определено.
| inherit_desc=T является полиморфным классовым типом
}}
Возможная реализация
namespace detail {
template <class T>
std::true_type detect_is_polymorphic(
decltype(dynamic_cast<const volatile void*>(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 { virtual void 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) |
проверяет, есть ли у типа виртуальный деструктор (шаблон класса) |