向后循环遍历枚举值

Looping backwards through enum values

本文关键字:枚举 遍历 循环      更新时间:2023-10-16

我正在学习C++,目前正在尝试制作一种名为weekdayenum类型,表示一周中的几天,以及一些在一天之间来回移动的基本函数。enum类型定义如下:

enum weekday {
    Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday
};

我想制作一个名为 changeDay 的函数,该函数将找到距离给定startDay delta 天的日期。(例如 changeDay(Monday, 4) == Friday)。我有这样定义的函数:

void incrementDay(weekday& startDay, int delta){
    startDay = weekday((startDay + delta) % 7);
}

只要我及时前进,这个函数就可以很好地工作(即 delta > 0)。但是,我也希望能够支持回到过去(即 delta < 0)。这导致了以下问题:例如,如果我想在星期二前 4 天去,我希望得到星期五。但是,按照我的函数的工作方式,将返回值-3,该值在我的weekday枚举中未定义为有效值。

我会尝试操作我的 changeDay 函数的值,以始终通过添加枚举的基数(7 + -3 = 4 = 星期五)来返回正值,但似乎"没有真正的好方法可以做到这一点"。(是的,我知道我可以在函数中对一周中的天数进行硬编码,但我对这种解决方案不感兴趣)。

有没有办法让我的函数向后循环我的枚举?

尝试以下操作

#include <iostream>
enum weekday 
{
    Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday
};
const char * weekday_name[] = 
{
    "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"
};
void incrementDay( weekday &startDay, int delta )
{
    if ( delta )
    {        
        delta %= Sunday + 1;
        if ( delta < 0 ) delta = Sunday + delta + 1;
        startDay = static_cast<weekday>( ( startDay + delta ) % ( Sunday + 1 ) );
    }       
}
int main()
{
    for ( int i = 0; i < 14; i++ ) 
    {
        weekday day = Monday;
        incrementDay( day, i );
        std::cout << day << ": " << weekday_name[day] << std::endl;
    }
    std::cout << std::endl;
    for ( int i = 0; i < 14; i++ ) 
    {
        weekday day = Monday;
        incrementDay( day, -i );
        std::cout << day << ": " << weekday_name[day] << std::endl;
    }
}    

程序输出为

0: Monday
1: Tuesday
2: Wednesday
3: Thursday
4: Friday
5: Saturday
6: Sunday
0: Monday
1: Tuesday
2: Wednesday
3: Thursday
4: Friday
5: Saturday
6: Sunday
0: Monday
6: Sunday
5: Saturday
4: Friday
3: Thursday
2: Wednesday
1: Tuesday
0: Monday
6: Sunday
5: Saturday
4: Friday
3: Thursday
2: Wednesday
1: Tuesday