当前位置:天才代写 > tutorial > C语言/C++ 教程 > C语言初学者的十八颗“地雷”

C语言初学者的十八颗“地雷”

2017-11-03 08:00 星期五 所属: C语言/C++ 教程 浏览:322

副标题#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);

这样做是不正当的,输入数据时不能划定精度。

#p#副标题#e#

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);
}

 

    关键字:

天才代写-代写联系方式