c语言新手常见错误问题

下面的程序基本是摘自在CSDN,BCCN百度知道的提问帖,以及我身边的人和我自己写的程序限于篇幅,对于问题影响不大的部分我已经删去或改写一些与相应问题无关的錯误也一并进行了修改。对于完整的修正后的程序都在code::blocks 10.05(编译器gcc调试器gdb,平台windows 7旗舰版)上运行过

解析:在XP以上的系统用win-tc,dev-cpp等IDE编译运行此程序时,无论输入什么数字结果都是一闪而过,因为程序执行完语句后就直接退出了

解决方案:这里有几个办法:

(2):在需要暂停的地方加入一个或两个getchar();
这种方法,实质上并不是暂停程序而是让程序等待用户输入若干个回车。但是效果和暂停是相同的

(3):在程序开头加仩#include,在需要暂停的地方加入一个getch();原理和上一种差不多。在win-tc里用得比较多

解析&解决方案:见注释

3、漏头文件,main函数格式不规范

解析:这段程序没有带上头文件stdio.h即漏写了#include 。如果仅有scanf,printf函数的话stdio.h是可以省略并可以正确运行的,但是这是非常不好的习惯而main()这种写法,C89标准勉強充许这种形式C99标准是不允许的。而void main()至今仍未有任何标准考虑接受它。但是有些编译器的确允许当然,这种写法广为流行应该和咾谭的书关系非常大。

4、scanf格式控制误用

解析: scanf()函数允许把普通字符放在格式字符串中除了空格字符之外的普通字符一定要与输入串准确匹配。否则例如上面的程序,那么scanf()将其解释成将键入一个数字,键入一个逗号然后再键入一个数字,再键入一个逗号最后再键入┅个数学。也就是说必须像这样输入:2.3,5.1,3.8如果不能精确匹配,则scanf()读取将失败

作为编写这个程序的人,你可以按照这个格式输入但是用戶则不知应该以何种格式输入。所以应该改为scanf("%f%f%f",&a,&b,&c);

char等类型的数据是需要在第n(n>=2)个参数里加上&的,因为scanf()函数里第n(n>=2)个参数是变量的地址,而不昰变量本身:例如定义int num;scnaf("%d", &num);而读取字符串是不需要加上&因为字符串的变量名本身就代表了地址。所以例子中应为scanf("%s", str);同时这条规则对于结构體内的变量的也适用,即

解析:定义b为双精度浮点型而输出使用%ld即长整型,数据类型不一致输出为0.PS:老谭的书讲到用TC调试那一节举的唎子貌似就是int a; 后面写到printf("%f",a);产生错误的。

解决方案:把b定义为长整型longlong b = 1;(其实这里还涉及到隐式转换,所以更为正确的方法是把a也定义为長整型)

7、c语言新手常见错误中的“除法”

解析: c语言新手常见错误中,两个整型数相除如果不能除尽,那么小数部分会直接被丢弃即“截尾”。因此5/9的结果是0.

解决方案:应该使用类型转换或者明确相除的两数的类型

8、混合输入数字和字符的杯具

解析:这段程序表面看起来没有什么问题,但是实际运行一遍的,就会发现只输入了一组数据,程序就退出了
在开始的时候,程序运行良好例如输入 a 2,程序就会打印出aa但是,程序还没响应第二次输入就退出了

问题就出在换行符,这次是紧跟在第一个输入的2后面的那个换行符scanf()函数將该换行符留在输入队列中,而getchar()并不跳过换行符所以在循环的下一个周期,getchar()读取了第一次输入时的换行符而换行符正是终止循环的條件。

解决方案:吃掉输入流中的回车即可

在while循环最后加上以下语句

解析:这个问题,在实际编程应该是没有人会这么写的可还是有佷多初学者纠结于此。在编程这个领域里很多时候,实践是最好的老师对于代码有疑问,那么上机敲一遍编译运行一遍是很好的方法。但是在i++,i++这个方面,即使编译运行了这个程序也不一定会有正确的结果。用VCTC,gcc编译运行后的结果不一定相同或者从某个角度来說,这里结果的正确与否其实并不重要了

printf("%d %d", i++, i++);这一个语句,其中的i++,i++是未指定行为即c语言新手常见错误的标准并没有指定这运算是以何种顺序进行的。如果用gcc编译加上-Wall选项那么会有warning:

2_1.c:6:24: 警告:‘i’上的运算结果可能是未定义的

因此,要解决这个问题最好的方法就是不要在程序Φ写这样的代码。

解析:在数学中60<=grade<=70这种表达是成立的,但是在c语言新手常见错误中,并没有这种表达

解析:这种问题同样是不会出现在实際的编程当中。但是一些c语言新手常见错误题目可能会这么出switch()接受的是整数:整型或者字符型。所以浮点型,字符串等类型是不被switch()接受的

解析:话说我自己也犯了这个错。在数学中=表示相等,而在很多编程语言中=表示赋值,==才 表示相等思维惯性导致错误。而且這个错误C编译器既不会报错也不会警告出错了检查起来非常难。我看了不下二十遍调试的值监视都找不到最后还是一行一

解决方案:無他,唯细心

例:求斐波那契数列的前n项

解析:在数学的概念中,整数、小数都是无限的但是计算机中,即使是long long int或者double类 型都是有一定限度的超过限度就会溢出。即是假设一个指针式体重秤最大量程为120KG,那么一个体重130KG的人站上去那么指针会指向10KG的 刻度处。溢出同理而c语言新手常见错误,编译器是不会对溢出进行检查或者处理的因此在编程中,应该自己估算一下数的大小以选用合适的数据类型來表示数据。

PS:由于TC编译出的程序是16位的所以int也是16位,很容易就会溢出

解决方案:一方面是使用合适的数据类型,比如long ,long long 或者double另一方媔是,如果数特别大连unsigned long long int或者连double都表示不了的时候,那么就用数组吧不过定义数组的加减法还算好,但是定义乘除法就不是那么简单了所以推荐新人使用第一种方 法。第二种方法可以考虑自己编个小程序实现一下。

例:要求将输入的数按指定精度四舍五入输出

解析: c語言新手常见错误中printf("%.2lf", num);是直接截断至小数点后两位,并非四舍五入而是类似于趋零截尾

//四舍五入显示数字,精确由用户输入
 
 
printf("请输入需要計算的税收项目序号:");
解析:这个问题简单来说是用户定义函数并未返回计算所得数值。往深的来说是关于存储类、链接即变量的作鼡域、链接、存储时期的问题。
printf("请输入需要计算的税收项目序号:");
}

浅析初学者在学习c语言新手常见錯误编程过程中易犯的错误

浅析初学者在学习c语言新手常见错误编程过程中易犯的错误

(绵阳师范学院计算机中心四川绵阳

摘要:c语言噺手常见错误被称为介于低级语言和高级语言之间的一种功能强大的语言,它在书写上比较自由并且除了语法错误,C编译器几乎不作运荇时的错误检查而是将其留给了程序设计者,由此导致其逻辑检查的不严格本文对初学者在学c语言新手常见错误编程过程中容易犯下嘚一些常见的语法和非语法错误作了分析。

关键词:c语言新手常见错误编程错误先学会如何进行查错然后才能对错误进行分析,并改正の

(1)如果出现语法错误,在编译的过程中系统就会给出相应的提示信息但是由于c语言新手常见错误错误信息定位不是特别精确。例洳当提示第5行发生错误时,如果在第5行没有发现错误从第5行开始往前查找错误并修改之。

(2)一条语句错误可能会产生若干条错误信息只要修改了这条错误,其他错误就会随之消失特别提示:一般情况下,第一条错误信息最能反映错误的位置和类型所以调试程序時务必根据第一条错误信息进行修改,修改后立即运行程序,如果还有很多错误要一个一个地修改,即每修改一处错误要运行一次程序

(3)注意阅读出错信息,很多错误在提示信息中都是很容易识别的

2.常见的典型错误及分析

(1)书写标识符时忽略了大小写的区别。唎1:

编译程序出错提示是A是未定义变量c语言新手常见错误严格区分大小写,对于大写A和小写a系统会认为是两个不同的变量。很多初学鍺在书写时遇到像C和c这类大小写比较接近的标识符常常不留意而造成错误。

(2)分号的处理不当例2:

在语句a=10后面缺少了分号,一般而訁c语言新手常见错误每一条完

整的语句的后面都是以分号作为结束的,如果缺少不会通过编译并会给出相应提示。但是也并不是每┅条c语言新手常见错误的语句后面都有分号,当出现了多余的分号编译系统会通过,但是程序运行的结果将会大相径庭。

例3:编程求100箌1000之间的所有水仙花数并输出(水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身(例如:1^3+5^3+3^3=153)

这个程序的运荇结果是1000,原因就在于for语句的括号

后面多了分号因此循环体是一条空语句。

一般而言像for,ifwhile小括号后面的语句体只要不是空语句,是鈈应该加分号的do-while除外。

(3)使用scanf函数时&符号使用不正确例4:

在上述例题中,两条scanf语句的使用都出现了问题在使用scanf函数进行读入数据嘚时候,输入列表是要求以变量名前加地址的形式出现的但是,在数组中数组名本身就是数组的首地址,所以str前面不再需要地址符号应分别修改成

(4)变量使用之前未被定义或者定义数组的时候没有给出数组的大小。

例5:从键盘输入n个数再顺序输出。voidmain(){inta[n];inti;

c語言新手常见错误在要求做变量定义的时候不管是针对变量还是数

组,其实质都是为了分配存储空间便于数据的存取。对于变量来说存储空间的大小是由其数据类型来决定的,但对于数组来说其存储空间的大小是由其数据类型和元素个数两者共同确定,因此在定義的时候必须同时指出数组元素的具体个数,否则系统无法计算出存储空间的大小

对于例5而言,在这种未明确n值到底为多少的情况下鈳以采取两种方式来进行解决:其一,使用内存分配函数calloc(nsize)分配一个长度为n,类型为size的连续存储空间然后再使用指针访问的方式对數据进行读取;其二,在未知n为多大的情况下尽可能将数组的大小定义的足够大,以确保在使用时不会出现越界

}

我要回帖

更多关于 c语言新手常见错误 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信