如何在C++中为枚举类型重载++运算符

3
这是我尝试过的方法,但我发现只有将变量赋值给另一个变量时,重载才会增加这个变量。 也就是说,在下面的示例中,变量newDay为THU,而currentDay仍为WED。
如何定义重载运算符以递增正在进行操作的变量?
typedef enum days {MON, TUE, WED, THU, FRI, SAT, SUN} days;

inline days operator++ (days& d) {
    return static_cast<days>((static_cast<int>(d) + 1) % 7);
}

int main(int argc, const char * argv[]) {
   days currentDay = WED;
   days newDay = ++currentDay;
   cout << "Current day: " << currentDay << ", Stored day: " << calendar[0] << ", New day: " << newDay << endl;
}

1
为什么您期望 static_cast<int>(d) + 1) % 7 增加某些东西,那个东西是什么? - n. m.
3
typedef enum days {...} days; 这句话有些累赘。只需要定义 enum days {...}; 即可。在 C++ 中,引入枚举类型不需要像 C 语言一样复杂。 - StoryTeller - Unslander Monica
考虑使用范围枚举 - suhdonghwi
2个回答

3
如果我把你的重载运算符修改成这样:
inline days operator++ (days const& d) {
    return static_cast<days>((static_cast<int>(d) + 1) % 7);
}

尽管我在那里添加了一个“const”修饰符,但它仍然可以编译。这是因为您没有像前缀“++”的语义要求的那样修改“d”。因此,如果您想要操作符产生预期效果,请确保对其进行修改:
inline days operator++ (days& d) {
    d = static_cast<days>((static_cast<int>(d) + 1) % 7);
    return d;
}

不评论您自己设计的有效性,但需要注意的是,广泛认为前缀 operator++ 应该返回可修改的左值,就像内置函数一样。请记住,如果您发现自己编写了类似于 ++x = y 的代码,则需要返回一个引用,即 date& operator++(date&)

请注意,取模运算符非常慢。增加值并与最大值进行比较会更快。 - The Science Boy

-1
你定义了后缀运算符。后缀运算符的正常行为是递增其参数的值,但返回原始值。它应该像这样表现:
days operator++(days& d,int){
    days temp=d;
    d=static_cast<days>((static_cast<int>(d) + 1) % 7);
    return temp;
}

你需要的是前缀运算符。它会增加参数的值并返回其引用。代码应该长这样:
days& operator++(days& d){
    d=static_cast<days>((static_cast<int>(d) + 1) % 7);
    return d;
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接