枚举的模板
Template for enum
本文关键字:枚举 更新时间:2023-10-16
如何为所有枚举指定模板。就像boost::serialization
一样。
升压:
template <typename Archive>
void serialize(Archive &AR, const unsigned int ver)
{
AR & enum__;
AR & int__;
AR & class__;
}
我需要所有枚举的operator&
:
struct A
{
void operator&(int obj){std::cout << "1";}
void operator&(unsigned int obj){std::cout << "2";}
template <typename T>
typename std::enable_if<std::is_enum<T>::value,void>::type operator&(T & obj) { std::cout << "Is enum" << std::endl; }
template<typename T>
void operator&(T & obj){obj.metod(); std::cout << "3";} // this operator not for enums
};
enum enum__{AAA,BBB};
enum enum2__{AAA2,BBB2};
int main()
{
A a;
enum__ d = AAA;
a & d;
enum2__ e = AAA2;
a & e;
std::system("pause");
return 0;
}
错误C2593:运算符&不明确
错误C2593:运算符&不明确
假设您将一个枚举类型传递给operator&
。然后编译器将生成具有相同函数参数的两个版本的operator&
。这就是为什么你犯了一个模棱两可的错误。您应该为非枚举:添加模板专用化
template<typename T>
typename std::enable_if<!std::is_enum<T>::value,void>::type
operator&(T & obj)
{
obj.metod();
std::cout << "3";
}
相关文章:
- 不带大括号的枚举形式
- 枚举环境变量的惯用C++14/C++17方法
- 类似枚举的计算常量
- 如何正确实现和访问运算符的各种自定义枚举器
- 错误:从"int"到枚举c++的转换无效
- C++中构造函数中的枚举
- 访问在 C++ 结构中声明的枚举变量
- 枚举类'classname'的多重定义
- 强枚举类型定义:Clang Bug 还是 C++11 标准不确定性?
- typedef 枚举和枚举类有什么区别?
- 为什么我的开关/机箱在使用枚举时默认?
- 标准::可选枚举的比较运算符
- C++两个源文件之间共享的枚举的静态实例
- 打印没有铸件的枚举可以在C++中吗?
- 枚举成员与静态 int 成员?
- C++:枚举:错误:应使用标识符而不是"}"
- 带有 c++ 的枚举(输入检查)
- 在 qml 中使用 Q_ENUM 和 Q_PROPERTY 作为枚举类
- 为什么 int 类型的枚举类值不能用作 int
- 在 C++ 中输出枚举类类型的向量元素