副标题#e#
C语言的最大特点是:成果强、利用利便机动。C编译的措施对语法查抄并不象其它高级语言那么严格,这就给编程人员留下“机动的余地”,但照旧由于这个机动给措施的调试带来了很多未便,尤其对初学C语言的人来说,常常会出一些连本身都不知道错在那边的错误。看着有错的措施,不知该如何改起,本人通过对C的进修,积聚了一些C编程时常犯的错误,写给列位学员以供参考。
1.书写标识符时,忽略了巨细写字母的区别。
main()
{
int a=5;
printf("%d",A);
}
编译措施把a和A认为是两个差异的变量名,而显示堕落信息。C认为大写字母和小写字母是两个差异的字符。习惯上,标记常量名用大写,变量名用小写暗示,以增加可读性。
2.忽略了变量的范例,举办了不正当的运算。
main()
{
float a,b;
printf("%d",a%b);
}
%是求余运算,获得a/b的整余数。整型变量a和b可以举办求余运算,而实型变量则不答允举办“求余”运算。
3.将字符常量与字符串常量夹杂。
char c;
c="a";
在这里就夹杂了字符常量与字符串常量,字符常量是由一对单引号括起来的单个字符,字符串常量是一对双引号括起来的字符序列。C划定以“\”作字符串竣事符号,它是由系统自动加上的,所以字符串“a”实际上包括两个字符:‘a’和‘\’,而把它赋给一个字符变量是不可的。
4.忽略了“=”与“==”的区别。
在很多高级语言中,用“=”标记作为干系运算符“便是”。如在BASIC措施中可以写
if (a=3) then …
但C语言中,“=”是赋值运算符,“==”是干系运算符。如:
if (a==3) a=b;
前者是举办较量,a是否和3相等,后者暗示假如a和3相等,把b值赋给a。由于习惯问题,初学者往往会犯这样的错误。
5.健忘加分号。
分号是C语句中不行缺少的一部门,语句末端必需有分号。
a=1
b=2
编译时,编译措施在“a=1”后头没发明分号,就把下一行“b=2”也作为上一行语句的一部门,这就会呈现语法错误。改错时,有时在被指出有错的一行中未发明错误,就需要看一下上一行是否遗漏了分号。
{
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;I<5;I++);
{scanf("%d",&x);
printf("%d",x);}
本意是先后输入5个数,每输入一个数后再将它输出。由于for()后多加了一个分号,使轮回体变为空语句,此时只能输入一个数并输出它。
#p#副标题#e#
7.输入变量时健忘加地点运算符“&”。
int a,b;
scanf("%d%d",a,b);
这是不正当的。Scanf函数的浸染是:凭据a、b在内存的地点将a、b的值存进去。“&a”指a在内存中的地点。
8.输入数据的方法与要求不符。
①scanf("%d%d",&a,&b);
输入时,不能用逗号作两个数据间的脱离符,如下面输入不正当:
3,4
输入数据时,在两个数据之间以一个或多个空格隔断,也可用回车键,跳格键tab。
②scanf("%d,%d",&a,&b);
C划定:假如在“名目节制”字符串中除了名目说明以外尚有其它字符,则在输入数据时应输入与这些字符沟通的字符。下面输入是正当的:
3,4
此时不消逗号而用空格或其它字符是差池的。
3 4 3:4
又如:
scanf("a=%d,b=%d",&a,&b);
输入应如以下形式:
a=3,b=4
9.输入字符的名目与要求纷歧致。
在用“%c”名目输入字符时,“空格字符”和“转义字符”都作为有效字符输入。
scanf("%c%c%c",&c1,&c2,&c3);
如输入a b c
字符“a”送给c1,字符“ ”送给c2,字符“b”送给c3,因为%c只要求读入一个字符,后头不需要用空格作为两个字符的隔断。
10.输入输出的数据范例与所用名目说明符纷歧致。
譬喻,a已界说为整型,b界说为实型
a=3;b=4.5;
printf("%f%d\n",a,b);
编译时不给出堕落信息,但运行功效将与原意不符。这种错误尤其需要留意。
11.输入数据时,诡筹划定精度。
scanf("%7.2f",&a);
这样做是不正当的,输入数据时不能划定精度。
12.switch语句中漏写break语句。
譬喻:按照测验后果的品级打印出百分制数段。
#p#分页标题#e#
switch(grade)
{
case 'A':printf("85~100\n");
case 'B':printf("70~84\n");
case 'C':printf("60~69\n");
case 'D':printf("<60\n");
default:printf("error\n");
}
由于漏写了break语句,case只起标号的浸染,而不起判定浸染。因此,当grade值为A时,printf函数在执行完第一个语句后接着执行第二、三、四、五个printf函数语句。正确写法应在每个分支后再加上“break;”。譬喻
case ‘A’:printf("85~100\n");break;
13.忽视了while和do-while语句在细节上的区别。
(1)main()
{int a=0,I;
scanf("%d",&I);
while(I<=10)
{a=a+I;
I++;
}
printf("%d",a);
}
(2)
main()
{int a=0,I;
scanf("%d",&I);
do
{a=a+I;
I++;
}while(I<=10);
printf("%d",a);
}
可以看到,当输入I的值小于或便是10时,二者获得的功效沟通。而当I>10时,二者功效就差异了。因为while轮回是先判定后执行,而do-while轮回是先执行后判定。对付大于10的数while轮回一次也不执行轮回体,而do-while语句则要执行一次轮回体。
14.界说数组时误用变量。
int n;
scanf("%d",&n);
int a[n];
数组名后用方括号括起来的是常量表达式,可以包罗常量和标记常量。即C不答允对数组的巨细作动态界说。
15.在界说数组时,将界说的“元素个数”误认为是可使的最大下标值。
main()
{static int a[10]={1,2,3,4,5,6,7,8,9,10};
printf("%d",a[10]);
}
C语言划定:界说时用a[10],暗示a数组有10个元素。其下标值由0开始,所以数组元素a[10]是不存在的。
16.初始化数组时,未利用静态存储。
int a[3]={0,1,2};
这样初始化数组是差池的。C语言划定只有静态存储(static)数组和外部存储(exterm)数组才气初始化。应改为:
static int a[3]={0,1,2};
17.在不该加地点运算符&的位置加了地点运算符。
scanf("%s",&str);
C语言编译系统对数组名的处理惩罚是:数组名代表该数组的起始地点,且scanf函数中的输入项是字符数组名,不须要再加地点符&。应改为:
scanf("%s",str);
18.同时界说了形参和函数中的局部变量。
int max(x,y)
int x,y,z;
{
z=x>y?x:y;
return(z);
}
形参应该在函数体外界说,而局部变量应该在函数体内界说。应改为:
int max(x,y)
int x,y;
{
int z;
z=x>y?x:y;
return(z);
}