我在访问包含在命名空间中的枚举时遇到了一些问题。
我的问题是我有两个名称空间用于两种不同的算法实现。问题是我有两个枚举每个命名空间中的模式,每个枚举略有不同。在一个文件中,我想比较两个实现。问题出现了,我不能在没有两次冲突的情况下使用枚举。任何人都可以描述我如何在没有using namespace
namespace implementation1{
enum modes {mode_standard, mode_special, fast_mode}
}
namespace implementation2{
enum modes {mode_default, mode_repeat, fast_mode}
}
请注意,这只是一个例子,我的有点复杂,但它展示了我想做的事情。我想尝试以这种方式解决它,而不是重构为全局枚举或重命名模式,但如果没有其他方法,这是一个选项。
答案 0 :(得分:3)
我不确定你的问题是什么,但这项工作对你有用吗?如果没有,请详细说明这个例子:
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获得。