1

我正在尝试从我正在处理的课程中删除警告。

警告如下:

警告 C4482:使用了非标准扩展:限定名称中使用了枚举“MyEnum”

我了解警告是由于尝试访问枚举中的值之一引起的,如下所示:

//Declared in a C header file.
enum MyEnum
{
    Value1,
    Value2,
    Value3 
};

//Exists in some other .cpp file.
void SomeFunc()
{
    MyEnum::Value1; //Generates warning C4482
}

仅供参考: SomeFunc() 存在于 .cpp 文件中,但枚举在 C 头文件中声明。

所以我可以删除警告的一种方法是用 Value1 替换 MyEnum::Value1。但是,我更愿意使用 MyEnum::Value1 来引用枚举值,因为我喜欢它更明确。

因此,如果我只使用 C++,我可以像这样更改枚举:

namespace MyEnum
{
    enum 
    {
        Value1,
        Value2,
        Value3 
    };
}

但是枚举存在于 C 头文件中,因此我无法将枚举包装在命名空间中。我也无法将枚举移动到 C++ 头文件中,因为其他文件已经依赖于枚举。

我考虑的一种方法是将枚举包装在一个结构中:

struct MyEnum
{
   enum Type
   { 
       Value1,
       Value2,
       Value3
   };
 };

这将允许我使用 MyEnum::Value1 访问值而不会发出警告。

但是,有没有更好的方法来实现这一点?

此外,我还遇到过枚举存在于 C++ 文件中但其作用域为类的情况:

class MyClass
{
    enum MyEnum
    {
        Value1,
        Value2,
        Value3
    };
};

我不想将它移出类,因为类提供了枚举的封装,但我也不能将枚举包装在命名空间中,因为类声明中不允许命名空间。在这种情况下是否有更好的方法来实现相同的行为 (MyEnum::Value1) 而不会发出相同的警告?

FYI2:我仅限于 vc10 允许的实现。

4

2 回答 2

3

我不相信标准 C 中有任何 :: 运算符,因此即使在结构中,枚举值也很可能只是全局符号。就像您在 C++ 中展示的那样,将它放在结构、类或命名空间中,可以使用该运算符访问它。

于 2019-02-04T03:26:59.790 回答
3

仅从 C++11 起,通过枚举名称限定枚举数是标准 C++。

在此之前,您无法MyEnum::Value1使用标准 C++ 编写代码。然而,微软甚至在标准化之前就允许它作为扩展。

VC10 警告您,您的资格是使用扩展而不是标准。如果内存服务于 C++11 不是 VC10 使用的默认标准。

由于这是一个 C 标头,并且枚举器名称始终是封闭范围的成员,因此您别无选择,只能以 C 方式“限定”它们

enum MyEnum { 
    MyEnum_Value1
};
于 2019-02-04T05:18:14.983 回答