揭露谭浩强错误二:枚举类型变量不能进行++,--等运算

谭老师的《C程序设计》,第314页,程序如下:

#include <stdio.h>
#include <stdlib.h>
void main()
{
enum color {red,yellow,blue,white,black};
enum color i,j,k,pri;
int n,loop;
n=0;
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=n+1;
    printf("%-4d",n);
    for(loop=1;loop<=3;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);
}

其中对枚举型变量的自增运算,在Vs2010和VC6.0中编译不通过,查阅后原因如下:

c++中枚举不能进行自增,自减运算,c可以 :
C++中,enum这种类型,运算时,会被隐式转换到int等类型,但是没有默认的int再回到enum的转换(除非你重载来自定义其行为,或者显式转换)。所以几乎没有针对enum类型本身的运算符,而是全被先转换了。转换后,就是赋值回来都不行,因为已经是整数了(除了直接把字面量赋给变量)。而++正是这种情况,因为它没法保证++后仍然是个合法的enum值,而编译器又不会在运行时去检查这种事,只好不允许了。其实enum能做的事并不怎么多,看起来就像是个符号常量而已,只不过编译器还能做点微簿的工作。比如,一个形参是enum类型,实参也一定得是,而形参是int类型,实参你可以用enum,这样可以转换,这只是避免赤裸裸地用数值直接量,用处并不是很大。如果形参接受的是enum,你用|位运算来按位或,都不行,除非你形参是unsigned int,然后用enum字面量值|的结果当实参。

解决方式是将 i++ 改为:i=(enum color)(i+1)  ,这样运行结果就正确了。

posted on 2012-10-28 21:29  天涯古人  阅读(753)  评论(0编辑  收藏  举报

导航