std:: integral_constant
|
Определено в заголовочном файле
<type_traits>
|
||
|
template
<
class
T, T v
>
struct integral_constant ; |
(начиная с C++11) | |
std::integral_constant
оборачивает статическую константу указанного типа. Это базовый класс для характеристик типов в C++.
Если программа добавляет специализации для
std::integral_constant
, поведение не определено.
Содержание |
Вспомогательные псевдонимы шаблонов
Вспомогательный шаблон псевдонима
std::bool_constant
определён для частного случая, когда
T
является
bool
.
|
template
<
bool
B
>
using bool_constant = integral_constant < bool , B > ; |
(начиная с C++17) | |
Специализации
Для распространённого случая, когда
T
является
bool
, предоставлены два определения типов:
|
Определено в заголовочном файле
<type_traits>
|
|
| Название | Определение |
true_type
|
std :: integral_constant < bool , true > |
false_type
|
std :: integral_constant < bool , false > |
Типы членов
| Название | Определение |
value_type
|
T |
type
|
std :: integral_constant < T, v > |
Константы-члены
| Название | Значение |
|
constexpr
T
value
[static]
|
v
(публичная статическая константа-член) |
Функции-члены
|
operator value_type
|
возвращает обёрнутое значение
(public member function) |
|
operator()
(C++14)
|
возвращает обёрнутое значение
(public member function) |
std::integral_constant:: operator value_type
|
constexpr
operator value_type
(
)
const
noexcept
;
|
||
Функция преобразования. Возвращает обёрнутое значение.
std::integral_constant:: operator()
|
constexpr
value_type operator
(
)
(
)
const
noexcept
;
|
(since C++14) | |
Возвращает обёрнутое значение. Эта функция позволяет
std::integral_constant
служить источником функциональных объектов времени компиляции.
Возможная реализация
template<class T, T v> struct integral_constant { static constexpr T value = v; using value_type = T; using type = integral_constant; // использование внедренного имени класса constexpr operator value_type() const noexcept { return value; } constexpr value_type operator()() const noexcept { return value; } // начиная с c++14 }; |
Примечания
| Макрос тестирования возможностей | Значение | Стандарт | Функция |
|---|---|---|---|
__cpp_lib_integral_constant_callable
|
201304L
|
(C++14) |
std::integral_constant::operator()
|
__cpp_lib_bool_constant
|
201505L
|
(C++17) |
std::bool_constant
|
Пример
#include <type_traits> using two_t = std::integral_constant<int, 2>; using four_t = std::integral_constant<int, 4>; static_assert(not std::is_same_v<two_t, four_t>); static_assert(two_t::value * 2 == four_t::value, "2*2 != 4"); static_assert(two_t() << 1 == four_t() >> 0, "2*2 != 4"); enum class E{ e1, e2 }; using c1 = std::integral_constant<E, E::e1>; using c2 = std::integral_constant<E, E::e2>; static_assert(c1::value != E::e2); static_assert(c1() == E::e1); static_assert(std::is_same_v<c2, c2>); int main() {}
Смотрите также
|
(C++14)
|
реализует последовательность целых чисел времени компиляции
(шаблон класса) |