免费注册 查看新帖 |

Chinaunix

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

脱裤子放屁的代码…… [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-08-09 18:35 |只看该作者 |倒序浏览
竟被公司元老列为好的习惯……


  1. ~dtor()
  2. {
  3.     if ( xx )
  4.     {
  5.         delete xx;
  6.         xx = NULL:
  7.     }
  8. }
复制代码


我说,都析构了,还 NULL 什么……


  1.   int ret = -1;

  2.   if ( xx )
  3.   {
  4.     assert(0);
  5.     goto exit;  // 汗……都assert了,还goto什么!而且我也很看不惯这种goto
  6.   }

  7.   ret = 0;
  8. exit:
  9.   return ret;
复制代码


你要 assert,直接 assert( !xx ) 不就好了!还 if 什么!是 assert 就不要 if,要 if 就不是 assert。怀疑他们是否连 assert 干什么用的都没搞清楚!

[ 本帖最后由 mmmixx 于 2007-8-9 18:40 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-08-09 18:37 |只看该作者
这个MJ挺熟

论坛徽章:
0
3 [报告]
发表于 2007-08-09 18:41 |只看该作者
你说的没错,其实这种 delete后再设NULL的代码,
在我看来简直就不可容忍!!
原因在于这个习惯,与其说使指针更安全,倒不如说某种程度上在鼓励隐藏一些bug,
隐藏bug带来的后果极其严重,会让你花费N倍的时间来寻找bug产生的原因。

论坛徽章:
0
4 [报告]
发表于 2007-08-09 18:43 |只看该作者
与其多花代码隐藏bug,不如设定检测条件多加assert,

论坛徽章:
0
5 [报告]
发表于 2007-08-09 18:47 |只看该作者
第一段代码确实是个好习惯
很多时候,如果你delete之后,不将它设为NULL的话
你可能会再次错误使用该指针,而暂时不发生错误
如果,你设了NULL则会马上发现该错误.

原帖由 mmmixx 于 2007-8-9 18:35 发表
竟被公司元老列为好的习惯……


~dtor()
{
    if ( xx )
    {
        delete xx;
        xx = NULL:
    }
}


我说,都析构了,还 NULL 什么……


  int ret = -1;

  if ( xx )
  { ...

论坛徽章:
0
6 [报告]
发表于 2007-08-09 18:48 |只看该作者
原帖由 飞灰橙 于 2007-8-9 18:41 发表
你说的没错,其实这种 delete后再设NULL的代码,
在我看来简直就不可容忍!!
原因在于这个习惯,与其说使指针更安全,倒不如说某种程度上在鼓励隐藏一些bug,
隐藏bug带来的后果极其严重,会让你花费N倍的时 ...


有道理,封装一方面也封装了出现bug的机会

论坛徽章:
0
7 [报告]
发表于 2007-08-09 19:05 |只看该作者
原帖由 ypxing 于 2007-8-9 18:47 发表
第一段代码确实是个好习惯
很多时候,如果你delete之后,不将它设为NULL的话
你可能会再次错误使用该指针,而暂时不发生错误
如果,你设了NULL则会马上发现该错误.


问题是,你在析构函数里还 NULL 什么 NULL 啊。而且,如果:
int *p1, *p2 = new int;
p1 = p2;
delete p2;
p2 = NULL;
p1 还照样不是 NULL 呢,用了 p1 怎么办?

论坛徽章:
0
8 [报告]
发表于 2007-08-09 19:10 |只看该作者
第二个assert,LZ自己没搞清吧
试想如果是非debug模式编译呢?

论坛徽章:
0
9 [报告]
发表于 2007-08-09 19:12 |只看该作者
同意楼上的

论坛徽章:
0
10 [报告]
发表于 2007-08-09 19:22 |只看该作者
原帖由 飞灰橙 于 2007-8-9 18:41 发表
你说的没错,其实这种 delete后再设NULL的代码,
在我看来简直就不可容忍!!
原因在于这个习惯,与其说使指针更安全,倒不如说某种程度上在鼓励隐藏一些bug,
隐藏bug带来的后果极其严重,会让你花费N倍的时 ...


比如说会有什么bug呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP