std::integral_constant (3) - Linux Manuals
std::integral_constant: std::integral_constant
Command to display std::integral_constant
manual in Linux: $ man 3 std::integral_constant
NAME
std::integral_constant - std::integral_constant
Synopsis
Defined in header <type_traits>
template< class T, T v > (since C++11)
struct integral_constant;
std::integral_constant wraps a static constant of specified type. It is the base class for the C++ type traits.
Helper templates
A helper alias template std::bool_constant is defined for the common case where T is bool. (since C++17)
template <bool B>
using bool_constant = integral_constant<bool, B>;
Two typedefs for the common case where T is bool are provided:
Defined in header <type_traits>
Type Definition
true_type std::integral_constant<bool, true>
false_type std::integral_constant<bool, false>
Member types
Type Definition
value_type T
type std::integral_constant<T,v>
Member constants
Name Value
constexpr T value static constant of type T with value v
(public static member constant)
[static]
Member functions
returns the wrapped value
operator value_type (public member function)
operator() returns the wrapped value
(public member function)
(C++14)
std::integral_constant::operator value_type
constexpr operator value_type() const noexcept;
Conversion function. Returns the wrapped value.
std::integral_constant::operator()
constexpr value_type operator()() const noexcept; (since C++14)
Returns the wrapped value. This function enables std::integral_constant to serve as a source of compile-time function objects.
Possible implementation
template<class T, T v>
struct integral_constant {
static constexpr T value = v;
typedef T value_type;
typedef integral_constant type; // using injected-class-name
constexpr operator value_type() const noexcept { return value; }
constexpr value_type operator()() const noexcept { return value; } //since c++14
};
Example
// Run this code
#include <iostream>
#include <type_traits>
int main()
{
typedef std::integral_constant<int, 2> two_t;
typedef std::integral_constant<int, 4> four_t;
// static_assert(std::is_same<two_t, four_t>::value,
// "two_t and four_t are not equal!");
// error: static assertion failed: "two_t and four_t are not equal!"
static_assert(two_t::value*2 == four_t::value,
"2*2 != 4"
);
enum class my_e {
e1,
e2
};
typedef std::integral_constant<my_e, my_e::e1> my_e_e1;
typedef std::integral_constant<my_e, my_e::e2> my_e_e2;
// static_assert(my_e_e1::value == my_e::e2,
// "my_e_e1::value != my_e::e2");
// error: static assertion failed: "my_e_e1::value != my_e::e2"
static_assert(std::is_same<my_e_e2, my_e_e2>::value,
"my_e_e2 != my_e_e2");
}
Pages related to std::integral_constant
- std::integer_sequence (3) - std::integer_sequence
- std::in_place,std::in_place_type,std::in_place_index,std::in_place_t, (3) - std::in_place,std::in_place_type,std::in_place_index,std::in_place_t,
- std::in_place,std::in_place_type,std::in_place_index,std::in_place_t,std::in_place_type_t,std::in_place_index_t (3) - std::in_place,std::in_place_type,std::in_place_index,std::in_place_t,std::in_place_type_t,std::in_place_index_t
- std::includes (3) - std::includes
- std::inclusive_scan (3) - std::inclusive_scan
- std::incrementable_traits (3) - std::incrementable_traits
- std::independent_bits_engine (3) - std::independent_bits_engine
- std::independent_bits_engine<Engine,W,UIntType>::base (3) - std::independent_bits_engine<Engine,W,UIntType>::base
- std::independent_bits_engine<Engine,W,UIntType>::discard (3) - std::independent_bits_engine<Engine,W,UIntType>::discard
- std::independent_bits_engine<Engine,W,UIntType>::independent_bits_engine (3) - std::independent_bits_engine<Engine,W,UIntType>::independent_bits_engine
- std::independent_bits_engine<Engine,W,UIntType>::max (3) - std::independent_bits_engine<Engine,W,UIntType>::max