10

我有一段与此非常相似的代码:

class someclass
{
public:
enum Section{START,MID,END};
vector<Section> Full;
void ex(){
    for(int i=0;i<Full.size();i++)
    {
        switch (Full[i])
        {
        case START :
                  cout<<"S";
                  break;
        case MID :
                  cout<<"M";
                  break;
        case END:
            cout<<"E";
            break;
        }
    }
    }
};

现在想象一下,我有更多的枚举类型,并且它们的名称更长....好吧,我得到的代码不是很好看,我想知道是否可以将特定的字符绑定到枚举类型,也许可以做这样的事情:

for(int i=0;i<Full.size();i++)
    {
        cout<(Full[i]).MyChar();
    }

或任何其他可以使此代码“更漂亮”的方法。这可能吗?

4

3 回答 3

19

不幸的是,您无能为力来清理它。如果您有权访问 C++11 强类型枚举器功能,那么您可以执行以下操作:

enum class Section : char {
     START = 'S',
     MID = 'M',
     END = 'E',
};

然后你可以做类似的事情:

std::cout << static_cast<char>(Full[i]) << std::endl;

但是,如果您无法访问此功能,那么您无能为力,我的建议是拥有一个全局 map std::map<Section, char>,它将每个enum部分与一个角色相关联,或者使用原型的辅助函数:

inline char SectionToChar( Section section );

它只switch()是以更易于访问的方式实现该语句,例如:

inline char SectionToChar( Section section ) {
     switch( section )
     {
     default:
         {
             throw std::invalid_argument( "Invalid Section value" );
             break;
         }
     case START:
         {
             return 'S';
             break;
         }
     case MID:
         {
             return 'M';
             break;
         }
     case END:
         {
             return 'E';
             break;
         }
     }
}
于 2013-06-13T19:46:26.493 回答
5

在这种情况下,您可能会很棘手并施放您的字符。

enum Section{
    START = (int)'S',
    MID   = (int)'M',
    END   = (int)'E'
};

...

inline char getChar(Section section)
{
    return (char)section;
}
于 2013-06-13T20:17:55.287 回答
0

我认为在这种情况下最好的解决方案是使用地图:

#include <iostream>
#include <map>
class someclass
{
    public:
    enum Section{START = 0,MID,END};
    map<Section,string> Full;

    // set using Full[START] = "S", etc

    void ex(){
        for(int i=0;i<Full.size();i++)
        {
            cout << Full[i];
        }
    }
};
于 2013-06-13T20:34:36.067 回答