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

标签 c++ enums namespaces

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

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

相关文章:

java - Eclipse“Java 已启动但返回退出代码=13

python - 用作返回类型时无法识别枚举名称

typescript - 联合类型枚举的参数?

javascript - Typescript 编译成的 javascript "namespace"模式的名称是什么?

vb.net - 导入 : Should you, 不应该吗,语法和最佳实践

ruby-on-rails - 是否可以在同一个 Rails 应用程序上拥有多个具有不同域名的网站?

c++ - NodeJS : Native c++ module with multi-threading (openmp)

c++ - 这是函数调用还是变量声明?

c++ - 如何使用所需的 BSTR* 参数正确调用 IDispatch::Invoke

c# - 按未知对象类型的值进行比较