gpt4 book ai didi

c++ - 访问命名空间中的枚举

转载 作者:搜寻专家 更新时间:2023-10-31 00:57:13 24 4
gpt4 key购买 nike

我在访问包装在命名空间中的枚举时遇到了一些问题。

我的问题是我有两个命名空间用于算法的两个不同实现。问题是我有两个枚举用于每个命名空间中的模式,每个都略有不同。在一个文件中,我想比较这两种实现。出现的问题是,如果两者不发生冲突,我就无法使用枚举。任何人都可以描述一下我如何在不使用 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com