◐ Shell
clean mode source ↗

std::value — cppreference.com

Материал из cppreference.com

<tbody> </tbody>

template< class T > struct value;

(начиная с C++11)

std::value является UnaryTypeTrait.

Если T является полиморфным классом (то есть класс, не являющийся объединением, который объявляет или наследует хотя бы одну виртуальную функцию), предоставляет константу-элемент {tt

Поведение программы, добавляющей специализации для std::is_polymorphic или std::is_polymorphic_v (начиная с C++17) не определено.

Параметры шаблона

Шаблон вспомогательной переменной

<tbody> </tbody>

template< class T > inline constexpr bool value_v = value<T>::value;

(начиная с C++17)

Унаследован от std::integral_constant

Константы элементы

true, если , false иначе
(public static константа-элемент)

Функции-элементы

преобразует объект в bool, возвращает value
(public функция-элемент)
возвращает 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

Смотрите также