草庐IT

C++ 使用声明与枚举 : how to import all the enum items?

这是演示我的问题的代码片段。namespaceN{enumE{A,B,C,D};}intmain(){usingN::E;Ee=A;//syntaxerror:'A'isnotdeclared}最后一行给我一个语法错误。我想使用名称N::A、N::B、N::C和N::D在没有命名空间限定符N::的主函数中。但是我不想做以下两件事(1)我不想说usingnamespaceN,因为那样会在N中导入其他一切。(2)我不想为枚举的每个成员说usingN::A、usingN::B等。因为如果我想修改枚举,我也必须更改我的主要功能。更不用说额外的输入既乏味又容易出错。我尝试自己寻找答案,但找不到。

c++ - 如何构建 NS-3 以使用 C++0x/C++11 库?

我需要在网络模拟器NS-3的代码中使用像unordered_map这样的数据结构。它使用wafbuilder编译源代码。我很困惑我应该在哪里添加-std=c++0x以添加到编译器标志?我尝试使用以下方法将它附加到主wscript文件中的CXXFlags:module.env.append_value('CXXFLAGS','-std=c++0x');但我仍然收到此错误:ThisfilerequirescompilerandlibrarysupportfortheupcomingISOC++standard,C++0x.Thissupportiscurrentlyexperimental

c++ - “static const”、 “#define” 和 “enum” 在性能和内存使用方面的区别

可能是因为#define语句的内联。我知道答案可能取决于编译器,那么假设是GCC。已有类似问题aboutC和aboutC++,但它们更多地是关于使用方面的。 最佳答案 编译器会在给定基本优化后将它们视为相同。检查起来相当容易-考虑以下C代码:#definea1staticconstintb=2;typedefenum{FOUR=4}enum_t;intmain(){enum_tc=FOUR;printf("%d\n",a);printf("%d\n",b);printf("%d\n",c);return0;}用gcc-O3编译:00

c++ - C/C++ : extract a subset of one enum to form a new enum

假设我有一个列出所有人员的主枚举:typedefenumall_personnel{//maleTONY,MIKE,JIM,//femaleJESSICA,MARY,}all_personnel_t;现在我想为male和female定义其他两个枚举(因为,例如,一些函数只接受males或females枚举参数),但我想使用与主枚举中相同的名称标识符。在C/C++中有可能吗?还是有其他方法?似乎以下内容不起作用(编译器提示redeclarationofenumerator‘TONY’等:typedefenummale_personnel{TONY,MIKE,JIM,}male_perso

c++ - Clang 与 GCC : Single-colon in Enum usage

以下代码使用g++-std=c++11编译,但不使用clang++-std=c++11。问题在此上下文中,单冒号“运算符”的含义是什么?澄清/编辑:GCC如何解释代码?如何让GCC不编译这段代码?(这里假设Clang遵循C++标准。)是否有针对此的标志?代码用g++-std=c++11main.cpp和clang++-std=c++11main.cpp编译。我正在使用GCC4.8和Clang6.0.0(主干)。#include#includeenumDir{LEFT,RIGHT};intmain(intargc,char**argv){//Interestingline:Noticet

c++ - 如何访问封装在类中的未命名的 "enum class"?

classA{public:enumclass{HELLO,WORLD};};知道了,在class中,声明一个简单的enum(而不是enumclass)是一个更好的主意,因为它已经使用class标识键入。但上面的语句仍然是一个有效的C++0x签名。现在如何访问外部未命名的enumclass?inti=A::HELLO;//error:‘HELLO’isnotamemberof‘A’ 最佳答案 实际上,这是无效的。C++0xFDIS说(9.2p1)Exceptwhenusedtodeclarefriends(11.3)ortointr

C++ "Floating Point Enum"

我正在寻找使用C++03标准的解决方案(几年来我一直被迫使用该版本的标准)。也欢迎C++11的解决方案,但不会“接受”作为此问题的答案。有什么简单明了的方法可以将一组相关的常量浮点值表示为单一类型(类似于枚举)以确保类型安全而不会产生大量开销,并且仍然允许我对这些值进行操作直接float?最终结果是我希望能够执行如下操作:enumFloatingPointEnum{VALUE1=0.1234f,...VALUEN=0.6789f};floatSomeFunction(FloatingPointEnumvalue){floatnew_value;/*performsomeoperatio

c++ - 为什么我会收到此 'enum' 不是类或命名空间错误?

我需要在我的Manager类中调用一个带有此签名的方法:voidcreatePlayer(Player&player,PlayerType&playerType);我有一个这样定义的玩家:usingnamespacestd;enumPlayerType{FORWARD,DEFENSEMAN,GOALIE};classPlayer{public:Player();voidsetType(PlayerType);private:PlayerTypetype;};这就是我尝试调用main中的方法的方式...#include"Player.h"#include"Manager.h"intmai

c++ - 这是 "new auto(enum_type)"的 Microsoft VC++ 2010 编译器错误吗

环境:MicrosoftVisualStudio2010withSP1Preminum(10.0.40219.1SP1Rel),WindowsXPSP3VC10编译器支持auto关键字,但推导的类型相关信息对于枚举似乎并不总是正确的。例子:#includeenumfruit_t{apple=100,banana=200,};intmain(){constautopa=newauto(banana);constautopb=newfruit_t(banana);static_assert(std::is_same::value,"notsame!");deletepb;deletepa;

c++ - `typedef enum {} t` 是否允许 C++0x 中的作用域枚举元素标识符?

我相信新的C++标准允许枚举类型有一个额外的“作用域”:enumE{e1,e2};Evar=E::e1;因为我知道很多包含旧C风格枚举类型定义的源文件,我想知道新标准是否允许对这些匿名枚举类型使用类型定义:typedefenum{d1,d2}D;Dvar=D::d1;//error? 最佳答案 新标准将添加一种新型的强枚举,但语法会略有不同,旧式枚举将兼容(C++03中的有效代码将是有效的C++0x代码)因此您将不需要做任何事情来保持遗留代码有效(不是typedef,不是其他任何东西)。enumclassE{e1,e2};//new