table of contents
        
      
      
    | std::underlying_type(3) | C++ Standard Libary | std::underlying_type(3) | 
NAME¶
std::underlying_type - std::underlying_type
Synopsis¶
 Defined in header <type_traits>
  
   template< class T > (since C++11)
  
   struct underlying_type;
  
   If T is a complete enumeration (enum) type, provides a member typedef
    type that
  
   names the underlying type of T.
  
   Otherwise, the behavior is undefined. (until C++20)
  
   Otherwise, if T is not an enumeration type, there is no member type.
  
   Otherwise (T is an incomplete enumeration type), the program is (since
    C++20)
  
   ill-formed.
  
   If the program adds specializations for std::underlying_type, the behavior is
  
   undefined.
Member types¶
 Name Definition
  
   type the underlying type of T
Helper types¶
 template< class T > (since C++14)
  
   using underlying_type_t = typename underlying_type<T>::type;
Notes¶
Each enumeration type has an underlying type, which can be
  
   1. Specified explicitly (both scoped and unscoped enumerations);
  
   2. Omitted, in which case it is int for scoped enumerations or an
  
   implementation-defined integral type capable of representing all values of
    the
  
   enum (for unscoped enumerations).
Example¶
// Run this code
  
   #include <iostream>
  
   #include <type_traits>
  
   enum e1 {};
  
   enum class e2 {};
  
   enum class e3 : unsigned {};
  
   enum class e4 : int {};
  
   int main()
  
   {
  
   constexpr bool e1_t = std::is_same_v<std::underlying_type_t<e1>,
    int>;
  
   constexpr bool e2_t = std::is_same_v<std::underlying_type_t<e2>,
    int>;
  
   constexpr bool e3_t = std::is_same_v<std::underlying_type_t<e3>,
    int>;
  
   constexpr bool e4_t = std::is_same_v<std::underlying_type_t<e4>,
    int>;
  
   std::cout
  
   << "underlying type for 'e1' is " << (e1_t ?
    "int" : "non-int") << '\n'
  
   << "underlying type for 'e2' is " << (e2_t ?
    "int" : "non-int") << '\n'
  
   << "underlying type for 'e3' is " << (e3_t ?
    "int" : "non-int") << '\n'
  
   << "underlying type for 'e4' is " << (e4_t ?
    "int" : "non-int") << '\n';
  
   }
Possible output:¶
 underlying type for 'e1' is non-int
  
   underlying type for 'e2' is int
  
   underlying type for 'e3' is non-int
  
   underlying type for 'e4' is int
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 2396 C++11 incomplete enumeration types were complete enumeration type
  
   allowed required
See also¶
 is_enum checks if a type is an enumeration type
  
   (C++11) (class template)
  
   is_scoped_enum checks if a type is a scoped enumeration type
  
   (C++23) (class template)
  
   to_underlying converts an enumeration to its underlying type
  
   (C++23) (function template)
| 2024.06.10 | http://cppreference.com |