10

我基本上有两个问题可能是相关的,所以我将它们合二为一。

在传递给函数时,我们应该通过引用还是值来传递 C++11 中的枚举类。它是一种继承原始类型,但它是传递的整个对象吗?因为枚举类是类型安全的;

enum class MyEnumClass : unsigned short {
    Flag1 = 0,
    Flag2 = 1,
    Flag3 = 2,
    Flag4 = 4,
};

现在假设我们有函数 sig

const char* findVal(const MyEnumClass& enumClass);
                                     ^
    should this be by const ref?   __|

我的另一个问题在这里-

SHOULD IT BE BY MOVE like (MyEnumClass&&) - I am still learning/understanding 
move semantics and rvalue so I am not sure if move semantics are only for 
constructors or can be for member or static funcs -
4

2 回答 2

4

它不是继承原始类型,而是告诉实现使用指定的 type( unsigned short) 作为枚举数的基础类型。

您可以简单地将枚举类对象视为任何其他类对象,并在将其传递给函数时应用相同的规则。

  • 如果要修改函数内部的枚举类对象,请通过引用传递。
  • 如果您只想读取函数内部的对象,请通过常量引用传递它。

移动语义是一种语言运行时性能增强功能,它利用从右值移动的机会,而不是应用性能密集型的复制语义。右值引用和移动语义不仅限于移动构造函数和移动赋值运算符,还可以与其他函数一起使用。如果您有可以使用此优化的场景,则可以使用它们。

于 2013-07-03T05:06:20.590 回答
4

考虑到枚举器使用指定的类型unsigned short作为基础类型,正如 Alok Save 指出的那样,按值传递此类对象可能是一个好主意(除非您想在函数中更改它们的值作为副作用,在这种情况下你应该使用参考。)

于 2013-07-03T06:04:04.460 回答