枚举应用出错,显示“不定义该运算符或到预定义运算符可接收的类型的转换”,请高手解答啊,谢谢!
定义了一个枚举,在for循环中用到了i++,可是编译的时候提示错误“errorC2676:二进制“++”:“color”不定义该运算符或到预定义运算符可接收的类型的转换”...
定义了一个枚举,在for循环中用到了i++,可是编译的时候提示错误“ error C2676: 二进制“++”: “color”不定义该运算符或到预定义运算符可接收的类型的转换”,请高手解答啊,谢谢!
typedef enum color
{
red,yellow,blue,white,black
};
enum color i,j,k,pri;
int main()
{
int n=0,loop;
for(i=red;i<=black;i++)
{
for(j=red;j<=black;j++)
{
if(i!=j)
{
for(k=red;k<=black;k++)
{
if((k!=i)&&(k!=j))
{
n+=1;
printf("%-4d",n);
for(loop=1;loop<4;loop++)
{
switch(loop)
{
case 1: pri=i;break;
case 2: pri=j;break;
case 3: pri=k;break;
default: break;
}
switch(pri)
{
case red: printf("%-10s","red");break;
case yellow: printf("%-10s","yellow");break;
case blue: printf("%-10s","blue");break;
case white: printf("%-10s","white");break;
case black: printf("%-10s","black");break;
default: break;
}
}
printf("\n");
}
}
}
}
}
printf("\ntotal:%-5d\n",n);
}
就算进行了强制类型转换(int)i++,还是不可以 展开
typedef enum color
{
red,yellow,blue,white,black
};
enum color i,j,k,pri;
int main()
{
int n=0,loop;
for(i=red;i<=black;i++)
{
for(j=red;j<=black;j++)
{
if(i!=j)
{
for(k=red;k<=black;k++)
{
if((k!=i)&&(k!=j))
{
n+=1;
printf("%-4d",n);
for(loop=1;loop<4;loop++)
{
switch(loop)
{
case 1: pri=i;break;
case 2: pri=j;break;
case 3: pri=k;break;
default: break;
}
switch(pri)
{
case red: printf("%-10s","red");break;
case yellow: printf("%-10s","yellow");break;
case blue: printf("%-10s","blue");break;
case white: printf("%-10s","white");break;
case black: printf("%-10s","black");break;
default: break;
}
}
printf("\n");
}
}
}
}
}
printf("\ntotal:%-5d\n",n);
}
就算进行了强制类型转换(int)i++,还是不可以 展开
3个回答
展开全部
c++中枚举不能进行自增,自减运算,c可以
抄录:
C++中,enum这种类型,运算时,会被隐式转换到int等类型,但是没有默认的int再回到enum的转换(除非你重载来自定义其行为,或者显式转换)。所以几乎没有针对enum类型本身的运算符,而是全被先转换了。转换后,就是赋值回来都不行,因为已经是整数了(除了直接把字面量赋给变量)。而++正是这种情况,因为它没法保证++后仍然是个合法的enum值,而编译器又不会在运行时去检查这种事,只好不允许了。其实enum能做的事并不怎么多,看起来就像是个符号常量而已,只不过编译器还能做点微簿的工作。比如,一个形参是enum类型,实参也一定得是,而形参是int类型,实参你可以用enum,这样可以转换,这只是避免赤裸裸地用数值直接量,用处并不是很大。如果形参接受的是enum,你用|位运算来按位或,都不行,除非你形参是unsigned int,然后用enum字面量值|的结果当实参。
抄录:
C++中,enum这种类型,运算时,会被隐式转换到int等类型,但是没有默认的int再回到enum的转换(除非你重载来自定义其行为,或者显式转换)。所以几乎没有针对enum类型本身的运算符,而是全被先转换了。转换后,就是赋值回来都不行,因为已经是整数了(除了直接把字面量赋给变量)。而++正是这种情况,因为它没法保证++后仍然是个合法的enum值,而编译器又不会在运行时去检查这种事,只好不允许了。其实enum能做的事并不怎么多,看起来就像是个符号常量而已,只不过编译器还能做点微簿的工作。比如,一个形参是enum类型,实参也一定得是,而形参是int类型,实参你可以用enum,这样可以转换,这只是避免赤裸裸地用数值直接量,用处并不是很大。如果形参接受的是enum,你用|位运算来按位或,都不行,除非你形参是unsigned int,然后用enum字面量值|的结果当实参。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询