小编推荐一个学 C 语言 / C++ 的学习裙 六九九, 四七零, 五九六 , 无论你是大牛还是小白, 是想转行还是想入行都可以来了解一起进步一起学习! 裙内有开发工具, 很多干货和技术资料分享!
1 书写标识符时, 忽略了大小写字母的区别
- 1
- 2
- 3
- 4
- 5
- main()
- {
- inta=5;
- printf(%d,A);
- }
编译程序把 a 和 A 认为是两个不同的变量名, 而显示出错信息 C 认为大写字母和小写字母是两个不同的字符习惯上, 符号常量名用大写, 变量名用小写表示, 以增加可读性
2 忽略了变量的类型, 进行了不合法的运算
- 1
- 2
- 3
- 4
- 5
- main()
- {
- floata,b;
- printf(%d,a%b);
- }
% 是求余运算, 得到 a/b 的整余数整型变量 a 和 b 可以进行求余运算, 而实型变量则不允许进行求余运算
3 将字符常量与字符串常量混淆
- 1
- 2
- charc;
- c=a;
在这里就混淆了字符常量与字符串常量, 字符常量是由一对单引号括起来的单个字符, 字符串常量是一对双引号括起来的字符序列 C 规定以作字符串结束标志, 它是由系统自动加上的, 所以字符串 a 实际上包含两个字符: a 和, 而把它赋给一个字符变量是不行的
4 忽略了 = 与 == 的区别
在许多高级语言中, 用 = 符号作为关系运算符等于如在 BASIC 程序中可以写
1if(a=3) then
但 C 语言中,= 是赋值运算符,== 是关系运算符如:
1if(a==3) a=b;
前者是进行比较, a 是否和 3 相等, 后者表示如果 a 和 3 相等, 把 b 值赋给 a 由于习惯问题, 初学者往往会犯这样的错误
5 忘记加分号
分号是 C 语句中不可缺少的一部分, 语句末尾必须有分号
1
2
a=1
b=2
编译时, 编译程序在 a=1 后面没发现分号, 就把下一行 b=2 也作为上一行语句的一部分, 这就会出现语法错误改错时, 有时在被指出有错的一行中未发现错误, 就需要看一下上一行是否漏掉了分号
- 1
- 2
- 3
- 4
- 5
- {
- z=x+y;
- t=z/100;
- printf(%f,t);
- }
对于复合语句来说, 最后一个语句中最后的分号不能忽略不写(这是和 PASCAL 不同的)
6 多加分号
对于一个复合语句, 如:
- 1
- 2
- 3
- 4
- 5
- {
- z=x+y;
- t=z/100;
- printf(%f,t);
- };
本意是先后输入 5 个数, 每输入一个数后再将它输出由于 for()后多加了一个分号, 使循环体变为空语句, 此时只能输入一个数并输出它
7 输入变量时忘记加地址运算符 &
- 1
- 2
- inta,b;
- scanf(%d%d,a,b);
这是不合法的 Scanf 函数的作用是: 按照 ab 在内存的地址将 ab 的值存进去 & 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=49 输入字符的格式与要求不一致
在用 %c 格式输入字符时, 空格字符和转义字符都作为有效字符输入
1scanf(%c%c%c,&c1,&c2,&c3);
如输入 a b c
字符 a 送给 c1, 字符 送给 c2, 字符 b 送给 c3, 因为 %c 只要求读入一个字符, 后面不需要用空格作为两个字符的间隔
小编推荐一个学 C 语言 / C++ 的学习裙 六九九, 四七零, 五九六 , 无论你是大牛还是小白, 是想转行还是想入行都可以来了解一起进步一起学习! 裙内有开发工具, 很多干货和技术资料分享!
10 输入输出的数据类型与所用格式说明符不一致
例如, a 已定义为整型, b 定义为实型
- 1
- 2
- a=3;b=4.5;
- printf(%f%d ,a,b);
编译时不给出出错信息, 但运行结果将与原意不符这种错误尤其需要注意
11 输入数据时, 企图规定精度
1scanf(%7.2f,&a);
这样做是不合法的, 输入数据时不能规定精度
12.switch 语句中漏写 break 语句
例如: 根据考试成绩的等级打印出百分制数段
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- switch(grade)
- {
- caseA:printf(85~100 );
- caseB:printf(70~84 );
- caseC:printf(60~69 );
- caseD:printf(<60 );
- default:printf(error );
- }
由于漏写了 break 语句, case 只起标号的作用, 而不起判断作用因此, 当 grade 值为 A 时, printf 函数在执行完第一个语句后接着执行第二三四五个 printf 函数语句正确写法应在每个分支后再加上 break; 例如
13 忽视了 while 和 do-while 语句在细节上的区别
- (1)
- 1
- caseA:printf(85~100 );break;
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- main()
- {
- inta=0,I;
- scanf(%d,&I);
- while(I<=10)
- {a=a+I;
- I++;
- }
- printf(%d,a);
- }
- (2)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- main()
- {
- inta=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 定义数组时误用变量
- 1
- 2
- 3
- intn;
- scanf(%d,&n);
- inta[n];
数组名后用方括号括起来的是常量表达式, 可以包括常量和符号常量即 C 不允许对数组的大小作动态定义
15 在定义数组时, 将定义的元素个数误认为是可使的最大下标值
- 1
- 2
- 3
- 4
- 5
- main()
- {
- staticinta[10]={1,2,3,4,5,6,7,8,9,10};
- printf(%d,a[10]);
- }
C 语言规定: 定义时用 a[10], 表示 a 数组有 10 个元素其下标值由 0 开始, 所以数组元素 a[10]是不存在的
小编推荐一个学 C 语言 / C++ 的学习裙 六九九, 四七零, 五九六 , 无论你是大牛还是小白, 是想转行还是想入行都可以来了解一起进步一起学习! 裙内有开发工具, 很多干货和技术资料分享!
16 在不应加地址运算符 & 的位置加了地址运算符
1scanf(%s,&str);
C 语言编译系统对数组名的处理是: 数组名代表该数组的起始地址, 且 scanf 函数中的输入项是字符数组名, 不必要再加地址符 & 应改为:
1scanf(%s,str);
17 同时定义了形参和函数中的局部变量
- 1
- 2
- 3
- 4
- 5
- 6
- intmax(x,y)
- intx,y,z;
- {
- z=x>y?x:y;
- return(z);
- }
形参应该在函数体外定义, 而局部变量应该在函数体内定义应改为:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- intmax(x,y)
- intx,y;
- {
- intz;
- z=x>y?x:y;
- return(z);
- }
来源: http://www.jianshu.com/p/20b8ee7947bd