元编程构造,它返回枚举的基础类型和迭代器的整数
Metaprogramming construct that returns underlying type for an enum and integer for an iteger
>我需要编写一个元编程结构,当给定枚举类型时,它返回该枚举的基础类型,但是当给定一个整数时,它返回该整数。
例如:
enum Enum : short { VALUE1, VALUE2 };
int_type<long>::type // -> long
int_type<Enum>::type // -> short
我试过这个
template< typename Type >
struct int_type {
using type = typename std::enable_if< std::is_enum<Type>::value, typename std::underlying_type<Type>::type >::type;
};
template< typename Type >
struct int_type {
using type = typename std::enable_if< std::is_integral<Type>::value, Type >::type;
};
但它抱怨结构的重新定义。
我也试过这个,但是
template< typename Type >
struct int_type {
using type = typename std::enable_if< std::is_enum<Type>::value, typename std::underlying_type<Type>::type >::type;
using type = typename std::enable_if< std::is_integral<Type>::value, Type >::type;
};
但随后它抱怨重新定义成员type
.
这就是我的元编程技能结束的地方,有人可以帮忙吗?
编辑:我还应该提到,我们的项目仅限于C++11。
你的尝试的问题在于你两次定义同一件事,尽管其中一部分使用了enable_if
,但当enable_if
不成立时,这不会使整个封闭定义被禁用。 也就是说,你有两个int_type::type
定义,即使其中一个(或两个(定义无效。
您正在寻找的是std::conditional
:
template< typename Type >
struct int_type {
using when_enum
= std::underlying_type<Type>;
using when_integral
= std::enable_if<std::is_integral<Type>::value, Type>;
using type
= typename std::conditional< std::is_enum<Type>::value,
when_enum, when_integral
>::type::type;
};
或者在 C++14 及更高版本中:
template< typename Type >
struct int_type {
using when_enum
= std::underlying_type<Type>;
using when_integral
= std::enable_if<std::is_integral<Type>::value, Type>;
using type
= typename std::conditional_t< std::is_enum<Type>::value,
when_enum, when_integral
>::type;
};
但我想我可能会把它写成别名模板:
template< typename Type >
using int_type = std::conditional_t<
std::is_enum<Type>::value,
std::underlying_type<Type>,
std::enable_if<std::is_integral<Type>::value, Type>>;
也许可以进一步简化它并int_type<T>
实际类型的别名,因此您无需说typename int_type<T>::type
:
template< typename Type >
using int_type = typename std::conditional_t<
std::is_enum<Type>::value,
std::underlying_type<Type>,
std::enable_if<std::is_integral<Type>::value, Type>>::type;
(注在 C++17 中,您可以使用 std::is_enum_v<Type>
和 std::is_integral_v
而不是说is_xxx<Type>::value
。
您可以通过部分专业化来做到这一点。
// primary template
template< typename Type, typename = void >
struct int_type {
};
// partial specialization for enum types
template< typename Type >
struct int_type <Type, typename std::enable_if< std::is_enum<Type>::value >::type > {
using type = typename std::underlying_type<Type>::type;
};
// partial specialization for integral types
template< typename Type>
struct int_type <Type, typename std::enable_if< std::is_integral<Type>::value >::type > {
using type = Type;
};
住
template< typename Type >
struct int_type {
using type = typename std::conditional< std::is_enum<Type>::value, typename std::underlying_type<Type>::type, Type >::type;
};
会做这个伎俩。可以链接 std::条件以选择不同的类型/生成错误。
相关文章:
- 将超出范围的整数分配给有符号字符类型
- 当我输入字符类型的数字时,为什么我无法获得整数?
- 整数类型应该显式转换(例如"int"到"无符号")还是只会增加混乱?
- 在 c++ 中,能够将浮点类型加 1 的最大整数是多少?
- 为什么 Clang 和 GCC 中两个无符号整数之和的结果类型不同
- 比较两个整数在C++中与未知 int 类型的相等性
- 如何在不给它任何类型(如整数)的情况下定义某物?
- 通过编译时值推断整数的类型
- C++/错误:表达式必须具有整数或无作用域枚举类型
- 从双精度转换为整数的显式类型是否始终检查整数溢出?
- 有没有办法将字符类型转换为整数?
- C++,概念不适用于无符号整数作为结果类型?
- 如何将整数分配给 char 类型的变量
- 类型转换问题:返回为整数而不是浮点/类型
- 涉及旧式枚举和整数类型的重载解析
- 将字符串转换为整数类型T,检查是否存在溢出
- 如何判断 c++ 向量中的值类型(整数或双精度)?
- 在 C/C++ 中,混合类型整数数学所需的最小类型向上转换是多少?
- 如何将字节数组转换为整数类型(整数、长整型、短型等)"安眠安"?
- 我可以在C++中制作一个强类型整数吗?