C言语的最大特点是:功用强、运用方便灵敏。C编译的程序对语法查看并不象其它高档言语那么严厉,这就给编程人员留下“灵敏的地步”,但仍是由于这个灵敏给程序的调试带来了许多不方便,特别对初学C言语的人来说,常常会出一些连自己都不知道错在哪里的过错。
1.书写标识符时,疏忽了巨细写字母的差异。
main()
{
int a=5;
printf(“%d”,A);
}
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);
};
又如:
I++;
再如:
{scanf(“%d”,&x);
printf(“%d”,x);}
7.输入变量时忘掉加地址运算符“&”。
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”,a,b);
编译时不给出犯错信息,但运转成果将与本意不符。这种过错特别需求留意。
11.输入数据时,妄图规则精度。
scanf(“%7.2f”,&a);
这样做是不合法的,输入数据时不能规则精度。
12.switch句子中漏写break句子。
例如:依据考试成绩的等级打印出百分制数段。
switch(grade)
{
case A:printf(“85~100”);
case B:printf(“70~84”);
case C:printf(“60~69”);
case D:printf(“<60");
default:printf(“error”);
}
case A:printf(“85~100”);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]);
}
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);