访问命名空间中的枚举

时间:2016-06-15 05:08:09

标签: 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}
}

请注意,这只是一个例子,我的有点复杂,但它展示了我想做的事情。我想尝试以这种方式解决它,而不是重构为全局枚举或重命名模式,但如果没有其他方法,这是一个选项。

1 个答案:

答案 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获得。