草庐IT

c++ - 好的风格——返回枚举还是整数?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭9年前。Improvethisquestion如果我有一个定义枚举的类,返回该枚举的成员函数应该声明为返回该枚举,还是返回一个int?例如:classFoo{public:enumStooge{larry,moe,curly};StoogeWhoToPoke();//OR:intWhoToPoke();???}我一直在声明返回枚举这样的方法,但不知道如果我将其声明为int是否是“更好的风格”或以某种方式对客户端更有用。

c++ - 在实现文件中使用 typedef 来缩短类型签名的负面后果是什么?

我正在用C++做我的第一个真正的项目,它是一个简单的CSV解析器(目前处于非常早期的阶段),我在头文件中有以下内容:classCsvReader{public://ActionstocommitoneachiterationoftheCSVparserenumAction{ADD_CHAR,ADD_FIELD,NONE};//ThepossiblestatesforeachcellofaCSVenumState{START,IN_FIELD,IN_QUOTED_FIELD,IN_QUOTED_QUOTE};//CreatethereaderfromafileexplicitCsvRea

c++ - 与常规枚举相比,C++ 枚举结构的大小是否更大?

与常规枚举相比,C++枚举结构(类)的大小是否更大?即,假设它们枚举相同的确切数据,什么会转化为更多字节的指令代码?我正在嵌入式环境中开发,这个问题很重要。我喜欢使用枚举结构允许的类型安全和作用域,但不会以代码膨胀为代价。 最佳答案 没有。语义上的差异由编译器管理,因为它只与类型系统有关。没有理由需要更多存储空间或需要更多说明。您可以使用sizeof轻松检查您的实际类型。但是,我应该注意,C++不保证任何此类类型的布局,只是说共享相同底层类型的两个枚举类型是“布局兼容的”([C++14:7.2/9]).

c++ - 表达式中使用的枚举数是否与其枚举的基础类型具有相同的类型?

当在无范围枚举定义之外使用时,枚举常量的类型是什么?考虑以下代码:#includeenummodes{begin=0,end=1};intmain(){std::cout::type>::value这在我的机器上产生:true4-99现在,如果我只将其他一些枚举器的值从begin更改为2147483648,那么我的输出将变为:true44294967197显然,这意味着end的类型已经从int变成了unsignedint,甚至底层的modes仍然相同(即unsignedint)。关于枚举的积分提升是否有一些特殊规则? 最佳答案 来自

c++ - 为枚举赋值

在审查一些旧代码时,我注意到以下两个使用枚举的奇怪结构(两个不同的文件/类/命名空间,只是在这里将它们放在一起):enumFirstEnum{A_CHOICE,ANOTHER_CHOICE=1,YET_SOME_OTHER_CHOICE};enumSecondEnum{FIRST_CHOICE,SECOND_CHOICE,THIRD_CHOICE,DEFAULT_CHOICE=SECOND_CHOICE};我认为这两种结构都是错误的。第一个为其中一个选项赋值,但不为其他选项赋值,这意味着如果添加新选项,事情可能会出错。在第二种情况下,我们最终得到两个具有相同基础值的枚举元素。C++标准

c++ - 应用关于如何递增枚举的规则

有没有办法改变枚举设置其常量值的方式?通常它会递增一个,但我想应用另一个规则。在PAWN中这会起作用enum(有没有办法在C++中做到这一点? 最佳答案 不是自动的,但是你可以手动指定每个值enumX{a=0x01,b=0x02,c=0x04}; 关于c++-应用关于如何递增枚举的规则,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/28808848/

c++ - 封装私有(private)枚举

之前我已经在类的头文件中定义了旨在私有(private)的枚举类型。private:enumfoo{a,b,c};但是,我不想再公开枚举的详细信息。在实现中定义枚举是否类似于定义类不变量?constintClassA::bar=3;enumClassA::foo{a,b,c};我想知道这是否是正确的语法。 最佳答案 C++没有枚举的前向声明,因此您不能将枚举“类型”与枚举“实现”分开。在C++0x中以下是可能的://foo.hclassfoo{enumbar:int;//mustspecifybasetypebarx;//canus

c++ - 如何优雅地将所有枚举放入 std::set

我有一个枚举,我想将它们全部放入集合中(然后使用set_intersection算法删除一些,但这是题外话)。除了我卡在第1步之外,一切都很好。:)如果我有(真实类具有更高基数的枚举)classMyClass{enumColor{red,green,blue}};我将如何初始化std::set包含所有枚举。我显然可以一个接一个地手动插入它们,做一个带强制转换的for循环,因为它们是连续的并且从0开始(我认为如果我不在枚举定义中使用=则这是必需的),但我正在寻找一种更优雅的方式。编辑:如果可能的话,我更喜欢C++03解决方案,因为当前的问题实例需要它,但如果不是,C++11也很好知道。

c++ - 为什么将枚举标记为导出/导入会中断 Doxygen 生成?

使用Doxygen,我偶然发现了这个警告:D://Camera.h:20:warning:documentedsymbol`enumDLLPORTct::CameraCapture::ct::CameraCapture::CamType'wasnotdeclaredordefined.现在我知道为什么Doxygen找不到那个类(命名空间显然是重复的),但我不明白的是它为什么还要搜索它。这个枚举在头文件中,在类定义的正上方,并且发现类很好,它也没有生成那些双命名空间。源代码也可以编译,所以它可能不是导致Doxygen这些问题的语法错误。具体来说,源代码如下所示:#ifdefCT_EXPO

c++ - 在 C++11 中,我可以引用在模板参数中定义的枚举类吗

这是我尝试编写的代码的简化版本:templateclassStateMachine{public:voidSetState(Derived::States){static_cast(this)->TransitionTo(s);}};classMyFSM:publicStateMachine{public:enumclassState{State1,State2,State3};voidTransitionTo(States){_state=s;}private:State_state=State::State1;};我正在使用带有clang的c++11。我在这里得到的错误是10:17