草庐IT

枚举法

全部标签

c++ - 为什么允许我使用不完整的枚举类?

为什么下面的代码编译没有任何错误?enumclassEnumeration;voidfunc(){autoenumeration=static_cast(2);autovalue=static_cast(enumeration);} 最佳答案 它编译是因为编译器在编译时知道Enumeration的大小(恰好是空的)。您可以使用以下语法明确地看到它:enumclassEnumeration:short;编译器知道关于Enumeration的所有信息。Enumeration是一个opaque-enum-declaration这也意味着该

c++ - 替换枚举以最大化编译时间检查的最佳方法

我有一个处理不同种类货币的相当老的应用程序。目前,货币存储在枚举中,例如:enumCURRENCY{EUR,USD,CNY};doubleconvertMoney(CURRENCYin,CURRENCYout,doublemoney_in){...}这工作很棒,除了这不是真正的类型安全:我还有其他包含注释的函数,例如WARNING:allinputsshouldhavethesamecurrency。我的目标是尽可能通过编译时检查替换这些注释中的大部分。我可以使用C++17和boost。我想到了使用std::variant这样:classEUR{};classUSD{};classCN

C++ 枚举类 std::size_t 隐式转换

我通过创建一个枚举类定义了一个元组及其索引:/**parameter{key;value1;value1;}*/usingParameter=std::tuple;enumclassParameterKey:std::size_t{KEY=0,VALUE1=1,VALUE2=2};现在我想从这个元组中获取一个值:constauto&key=std::get(*parameterPointer);我认为从int到std::size_t的隐式转换是由:std::size_t语法确保的:enumclassParameterKey:std::size_t{....}但是我收到了这个错误erro

c++ - 是否嵌套枚举类?

一个人可以有独立的枚举类:enumclassStreamOpenMode{read,write,readWrite};classStream{public:Stream(StreamOpenModeopenMode)//...};或者将它们嵌套在另一个类中:classStream{public:enumclassOpenMode{read,write,readWrite};Stream(OpenModeopenMode)//...};选择一个而不是另一个的技术原因是什么?例如,嵌套变体不能前向声明,这可能会导致大型项目中的循环依赖问题。 最佳答案

c++ - 如何让 Oxygen 到 "link"以枚举定义?

我有以下代码:///\fileDoxygen_tests.h/****\enumTick_Column_Type**\briefValuesthatrepresentTick_Column_Type.**/enumTick_Column_Type{TC_OPEN,///一切似乎都工作正常(枚举最终在文件范围内结束,但我有一个\file,所以它与描述一起出现,格式正确。我想要(但没有发生)的是,我希望Tick_Data_Row::m_cols文档中对Tick_Column_Type的引用链接回该文档页面。Doxygen通常似乎很聪明地弄清楚“啊哈,这是一个我知道的名字,我会热链接它”,但

c++ - Visual 2010 中带有 lambda 函数和枚举的 C2665,是错误还是正常?

我可以编译以下代码:enumE{a,b,c};voidf(){Ee;std::functionf=[&](){e=a;};}但不是下面的:voidf(){enumE{a,b,c};Ee;std::functionf=[&](){e=a;};}发出以下编译器错误:1>test.cpp(5):errorC2665:'`anonymous-namespace'::::':noneofthe2overloadscouldconvertalltheargumenttypes1>test.cpp(5):couldbe'`anonymous-namespace'::::(f::E&,f::E&)'1

c++ - 如何从 boost::property_tree 获取枚举?

如何从boost::property_tree中获取枚举?这是我的“非工作”示例。配置文件EMISSION::EMIT142main.cpp#include#include#includeintmain(){enumclassEMISSION{EMIT1,EMIT2};enumEMISSIONmyEmission;//InitializetheXMLfileintoproperty_treeboost::property_tree::ptreept;read_xml("config.xml",pt);//testenum(SUCCESS)myEmission=EMISSION::EMI

c++ - 在 C++ 中显示、更新和验证枚举值

#includeenumSEX{MALE,FEMALE};intmain(intargc,char**argv){enumSEXthe_sex=MALE;return0;}如何在终端或控制台上显示the_sex值,从终端或控制台接受值以更新the_sex的值,以及如何验证the_sex变量的输入? 最佳答案 HowcanIacceptvaluesfromtheterminalorconsoletoupdatethevalueofthe_sexandhowcanIvalidtheinputforthe_sexvariable?输入可以

c++ - 使用 size_t 索引以相反的顺序枚举数组

假设我们需要以相反的顺序打印大小为N的int数组://Wrong,iisunsignedandalways>=0:for(size_ti=N-1;i>=0;--i){cout=0;--i){cout0;--i){cout是否有更好的方法来使用size_t索引进行此类枚举并且无需在循环中进行额外操作?假设(size_t)0-1给出(size_t)(-1)还是未定义是否有效? 最佳答案 您可以将减量移动到条件“之后”。for(size_ti=N;i>0;){--i;cout它不像前向循环那么优雅,但它可以工作。我们在0处中断,所以i永远

c++ - 使用枚举基编写枚举时出现不明确的重载,但仅使用 clang

我想使用operator#includeenummyenum:uint16_t{X=0,};intmain(){std::coutgcc4.8和visualstudio2015没有这个问题。clang++-3.6错误#clang++-3.6-std=c++11-O0ostream.cpp-otest.exeostream.cpp:18:29:error:useofoverloadedoperator'>'and'myenum')std::cout总的来说,在严格遵守方面,我倾向于相信clang,所以也许使用确实是模棱两可的。枚举当然可以转换为其他类型的整数。我希望编译器更喜欢与枚举的基