免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4383 | 回复: 16
打印 上一主题 下一主题

[C] 求教--C语言 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-02-16 23:40 |只看该作者 |倒序浏览
这两天看了一本书上的代码,是一个if条件语句的比较。
if(-1==pid);
我记得当初学C语言的时候,教材上的例子基本上都是
if(x==-1);
这种形式的。

那么,把常数放在前面是不是有什么特殊的含义?
这两种写法有什么区别?
哪种写法比较好?
或者,在哪种情况下用哪种写法呢?

坐等高手抽空指导。谢谢。

论坛徽章:
0
2 [报告]
发表于 2011-02-17 07:04 |只看该作者
由于许多人容易把
if(x==-1)
写成
if(x=-1)

所以有人就想出了一个馊主意
把常量写在前面
if(-1==pid)
这样如果误写成了
if(-1=pid)
的话
编译器可以马上发现

在我看来,这不是好办法,更不是根本解决问题的办法
因为如果“==”的两个运算对象中没有常量的话
这种办法立刻失灵
所以说是馊主意

根本的解决办法是养成好习惯把“=”读成“赋值”。这个运算也确实是赋值的意思

论坛徽章:
0
3 [报告]
发表于 2011-02-17 08:43 |只看该作者
同意楼上,写成 if ( -1 == pid ) 好处不大,但对阅读代码来说非常别扭

至于将 == 误写成 = ,实际上大多数的编译器都会给出warning的

更重要的时,这样的bug只要运行一次就能马上发现,单元测试,代码运行覆盖度测试,是良好习惯,不但能发现这样的bug,而且能发现大部分的局部bug。

现在很多人写代码,特别是其中异常情况处理相关的代码,到系统上线都没有被跑过一次(因为很多情况出现的概率很低),这样的系统风险很大的

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
4 [报告]
发表于 2011-02-17 08:45 |只看该作者
好像是林锐的书上是倒着写的,很多人跟着学

论坛徽章:
0
5 [报告]
发表于 2011-02-17 08:49 |只看该作者
习惯问题,没什么区别
最好还是 变量==常量

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
6 [报告]
发表于 2011-02-17 09:31 |只看该作者
看自己了

论坛徽章:
0
7 [报告]
发表于 2011-02-17 10:02 |只看该作者
gcc -Wall 参数可以检测到此类赋值。

论坛徽章:
0
8 [报告]
发表于 2011-02-17 10:25 |只看该作者
这样写是为了避免出现误写 比如 把 if(i == 3) 误写为 if(i = 3)  这时程序不会报错 但是得到的结果却变了...

论坛徽章:
0
9 [报告]
发表于 2011-02-17 10:35 |只看该作者
同意楼上,写成 if ( -1 == pid ) 好处不大,但对阅读代码来说非常别扭

至于将 == 误写成 = ,实际上大多 ...
drangon 发表于 2011-02-17 08:43



冒个泡, 你说了我想说的

论坛徽章:
0
10 [报告]
发表于 2011-02-17 10:49 |只看该作者
if(==) 写错是大问题, 编译警告级别高的话可以报警
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP