《C陷阱与缺陷》

1、【词法陷阱】

1.1 符号与组成符号间的关系

1、符号间的空白(空格符、制表符、换行符)将被忽略

1.1 = 与 ==

1.3 y = x/*p 与 y = x/(*p),a=-1 与 a =- 1 与 a = -1, 老版本编译器的处理是不同的,严格的ANSI C则会报错

在这里插入图片描述

1.4 十进制的 076,会被处理为八进制,ANSI C禁止这种用法!

1.5 字符与字符串:‘a’(表示十进制的97) 与 “n”

用单引号括起的一个字符代表一个整数,而用双引号括起的一个字符代表一个指针,混用会出问题。

2、【语法陷阱】

2.1 函数声明

在这里插入图片描述

2.2 ☆☆☆ 运算符的优先级

☆☆☆ if (flags & FLAG) 、if (flags & FLAG != 0) 、 if (flags & (FLAG != 0))

在这里插入图片描述

☆☆☆ r = hi<<4 + low、r = hi << (4 + low)

在这里插入图片描述

☆☆☆ 运算符优先级表:

(1)赋值 = 的优先级是最低的!

(2)任何一个逻辑运算符 优先级低于 任一个关系运算符

☆☆☆ while(c=getc(in) != EOF) 、while((c=getc(in)) != EOF)

☆☆☆ if ((t=BTYPE(pt1->aty)==STRTY) || t==UNIONTY) {

这里就是先判断==,再进行=
在这里插入图片描述

2.3 注意语句结束标志的符号:缺少;多了;

2.4 swtich 语句:容易遗失break

2.5 函数调用:f() 调用函数,f 函数地址

2.6 悬挂 else 引发的问题

3 ☆☆☆ 【语义陷阱】

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值