我在访问包装在命名空间中的枚举时遇到了一些问题。
我的问题是我有两个命名空间用于算法的两个不同实现。问题是我有两个枚举用于每个命名空间中的模式,每个都略有不同。在一个文件中,我想比较这两种实现。出现的问题是,如果两者不发生冲突,我就无法使用枚举。任何人都可以描述一下我如何在不使用 using namespace
namespace implementation1{
enum modes {mode_standard, mode_special, fast_mode}
}
namespace implementation2{
enum modes {mode_default, mode_repeat, fast_mode}
}
请注意,这只是一个示例,我的示例有点复杂,但它演示了我想做什么。我想尝试以这种方式解决它,而不是重构为全局枚举或重命名模式,尽管如果没有其他方法,这是一个选项。
最佳答案
我不确定你的问题是什么,但这对你有用吗?如果不是,请详细说明示例:
namespace implementation1 {
enum modes { mode_standard, mode_special, fast_mode };
}
namespace implementation2 {
enum modes { mode_default, mode_repeat, fast_mode };
}
int main(int argc, char *argv[]) {
if (implementation1::fast_mode == implementation2::fast_mode) { // foo mode use...
}
return 0;
}
更新 enum
会破坏你的“等效性”:
namespace implementation1 {
enum modes { mode_standard, mode_special, fast_mode };
}
namespace implementation2 {
enum modes { first_mode, mode_default, mode_repeat, fast_mode };
}
int main(int argc, char *argv[]) {
// foo mode use... this not work now
if (implementation1::fast_mode == implementation2::fast_mode) {
}
return 0;
}
enum
值是自动分配的,如果你需要比较他名字中的enum
,你需要手动管理“分配的值”:
namespace implementation1 {
enum modes { mode_standard, mode_special, fast_mode = 3 };
}
namespace implementation2 {
enum modes { first_mode, mode_default, mode_repeat, fast_mode = 3 };
}
但它很容易出错,我强烈建议不要使用它,如果你
需要这方面的详细信息我推荐read关于新的动机scoped枚举(例如:enum class
),可从 c++11 获得。
关于c++ - 访问命名空间中的枚举,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37826585/