1、 二级 C 语言编程常见的18种错误C 语言的最大特点是:功能强、使用方便灵活。C 编译的程序对语法检查并不象其它高级语言那么严格,这就给编程人员留下“ 灵活的余地”,但还是由于这个灵活给程序的调试带来了许多不便,尤其对初学 C 语言的人来说,经常会出一些连自己都不知道错在哪里的错误。看着有错的程序,不知该如何改起,校园网整理了一些 C 编程时常犯的错误,写给各位学员以供参考。1.书写标识符时,忽略了大小写字母的区别main()int a=5;printf(“%d“,A);编译程序把 a 和 A 认为是两个不同的变量名,而显示出错信息。 C 认为大写字母和小写字母是两个不同的字符。习惯上,符号
2、常量名用大写,变量名用小写表示,以增加可读性。2.忽略了变量的类型,进行了不合法的运算。main()float a,b;printf(“%d“,a%b);%是求余运算,得到 a/b 的整余数。整型变量 a 和 b 可以进行求余运算,而实型变量则不允许进行“求余” 运算。3.将字符常量与字符串常量混淆。char c;c=“a“;在这里就混淆了字符常量与字符串常量,字符常量是由一对单引号括起来的单个字符,字符串常量是一对双引号括起来的字符序列。C 规定以“”作字符串结束标志,它是由系统自动加上的,所以字符串“a”实际上包含两个字符:a和,而把它赋给一个字符变量是不行的。4.忽略了“=”与“= =”
3、 的区别。在许多高级语言中,用“=”符号作为关系运算符“ 等于 ”。如在 BASIC 程序中可以写if (a=3) then 但 C 语言中, “=”是赋值运算符, “=”是关系运算符。如:if (a=3) a=b;前者是进行比较,a 是否和3相等,后者表示如果 a 和3相等,把 b 值赋给 a。由于习惯问题,初学者往往会犯这样的错误。5.忘记加分号。分号是 C 语句中不可缺少的一部分,语句末尾必须有分号。a=1b=2编译时,编译程序在“a=1”后面没发现分号,就把下一行“b=2” 也作为上一行语句的一部分,这就会出现语法错误。改错时,有时在被指出有错的一行中未发现错误,就需要看一下上一行是否
4、漏掉了分号。z=x+y;t=z/100;printf(“%f“,t);对于复合语句来说,最后一个语句中最后的分号不能忽略不写(这是和 PASCAL 不同的)。6.多加分号。对于一个复合语句,如:z=x+y;t=z/100;printf(“%f“,t);复合语句的花括号后不应再加分号,否则将会画蛇添足。又如:if (a%3=0);I+;本是如果3整除 a,则 I 加1。但由于 if (a%3=0)后多加了分号,则 if 语句到此结束,程序将执行 I+语句,不论3是否整除 a,I 都将自动加1。再如:for (I=0;I10时,二者结果就不同了。因为 while 循环是先判断后执行,而 do-wh
5、ile 循环是先执行后判断。对于大于10的数 while 循环一次也不执行循环体,而 do-while 语句则要执行一次循环体。14.定义数组时误用变量。int n;scanf(“%d“,int an;数组名后用方括号括起来的是常量表达式,可以包括常量和符号常量。即 C 不允许对数组的大小作动态定义。15.在定义数组时,将定义的“元素个数”误认为是可使的最大下标值。main()static int a10=1,2,3,4,5,6,7,8,9,10;printf(“%d“,a10);C 语言规定:定义时用 a10,表示 a 数组有10个元素。其下标值由 0开始,所以数组元素 a10是不存在的。1
6、6.初始化数组时,未使用静态存储。int a3=0,1,2;这样初始化数组是不对的。C 语言规定只有静态存储(static)数组和外部存储(exterm)数组才能初始化。应改为:static int a3=0,1,2;17.在不应加地址运算符C 语言编译系统对数组名的处理是:数组名代表该数组的起始地址,且 scanf 函数中的输入项是字符数组名,不必要再加地址符18.同时定义了形参和函数中的局部变量。int max(x,y)int x,y,z;z=xy?x:y;return(z);形参应该在函数体外定义,而局部变量应该在函数体内定义。应改为:int max(x,y)int x,y;int z;z=xy?x:y;return(z);