免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: pprpg
打印 上一主题 下一主题

[C] ( 转 )Linus Torvalds:大多黑客甚至连指针都未理解 [复制链接]

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
41 [报告]
发表于 2013-01-11 12:01 |只看该作者
回复 33# pmerofc


我也是,就像你改过的,直接操作head,我之前还发帖子说那种写法,但是看到循环里面的变量先引起疑问,

我就把后面的忽略了

思维太容易被打断了,最近想事情比较多,想一个过一会就忘,看来我又应该 随身带纸笔了

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
42 [报告]
发表于 2013-01-11 12:03 |只看该作者
回复 39# bsdc


    一个是给二级指针指向者即一级指针赋值,一个是给二级指针赋值

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
43 [报告]
发表于 2013-01-11 12:18 |只看该作者
本帖最后由 zylthinking 于 2013-01-11 13:44 编辑
pmerofc 发表于 2013-01-10 20:39
回复 1# pprpg


我大乐, 将 for 改成 while 就自以为牛了, 还自以为少了一个中间变量而自鸣得意???
1. 首先, linus 批判的是不使用双重指针而只能在代码内使用变量记住前一个元素地址的代码, 因此, 所有本质上和linus 思路一致的都别舔着脸自以为是;
2. 代码改的也是 bug 侧漏, 至少与 linus 原来代码不一致; 看来经过了这么久, 专家的编码水平还是原地踏步

还想着给人解毒呢??? 你就不能不被人揪小辫子么

防止专家改代码, 及方便比较, 作个备份, 专家代码
  1. void remove_if(node ** head, remove_fn rm)  
  2.     {  
  3.         node * entry ;
  4.         while( (entry = *head)!=NULL )  
  5.         {  
  6.             if (rm(entry))  
  7.             {  
  8.                 *head = entry->next;  
  9.                 free(entry);  
  10.             }  
  11.             else  
  12.                 head= &entry->next;  
  13.         }  
  14.     }
复制代码
linus 原来代码:

  1.     void remove_if(node ** head, remove_fn rm)  
  2.     {  
  3.         for (node** curr = head; *curr; )  
  4.         {  
  5.             node * entry = *curr;  
  6.             if (rm(entry))  
  7.             {  
  8.                 *curr = entry->next;  
  9.                 free(entry);  
  10.             }  
  11.             else  
  12.                 curr = &entry->next;  
  13.         }  
  14.     }  
复制代码
日了日了, 是我搞错了, 被抓住小辫子了

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
44 [报告]
发表于 2013-01-11 12:24 |只看该作者
群雄逐鹿中原 发表于 2013-01-10 19:59
这里有性能问题,大神并非毫无破绽 --
  if (rm(entry))  
         *curr = entry->next;  


这个 *cur = XXX 也未必一定要在内存记录 next 指针, 编译器的优化未必不能做

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
45 [报告]
发表于 2013-01-11 12:39 |只看该作者
zylthinking 发表于 2013-01-11 12:24
这个 *cur = XXX 也未必一定要在内存记录 next 指针, 编译器的优化未必不能做


除非编译时能理解 free 函数的语义。难。。

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
46 [报告]
发表于 2013-01-11 12:50 |只看该作者
群雄逐鹿中原 发表于 2013-01-11 12:39
除非编译时能理解 free 函数的语义。难。。


是的, 但就算不能优化存在所谓的性能问题, 也是算法问题, 在一次循环中不处理当前节点而去寻找下几个节点是否一样应该被删除, 就算存在这样的方法, 就可读性而言, 也不是什么好事; 而且, 这样存在分支判断, 就处理器流水线而言, 不是什么好事; 相反, *curr = entry->next; 之前,  *cur 已经在 entry 赋值时被访问过, 缓存不命中的可能性很小。

嗯, 我就是你和我谈C语言, 我和你谈编译器及体系结构的典型

论坛徽章:
0
47 [报告]
发表于 2013-01-11 12:59 |只看该作者
回复 43# zylthinking

没看懂。。。。
能不能请教下您说的pm修改后的bug和不一致在什么地方?

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
48 [报告]
发表于 2013-01-11 13:19 |只看该作者
sqfasd 发表于 2013-01-11 12:59
回复 43# zylthinking

没看懂。。。。


*head 在 linus 代码下没有被修改, 专家的改了; 不要说应该改, 不再使用了之类的, 然后将这个 bug 算在 linus 头上, 或者我吹毛求疵之类的, linus 在先, 那么后继就应该严格保证行为一致

论坛徽章:
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
49 [报告]
发表于 2013-01-11 13:24 |只看该作者
zylthinking 发表于 2013-01-11 13:19
*head 在 linus 代码下没有被修改, 专家的改了; 不要说应该改, 不再使用了之类的, 然后将这个 bug  ...


何必耿耿于怀,应当视而不见

论坛徽章:
4
天秤座
日期:2013-10-18 13:58:33金牛座
日期:2013-11-28 16:17:01辰龙
日期:2014-01-14 09:54:32戌狗
日期:2014-01-24 09:23:27
50 [报告]
发表于 2013-01-11 13:24 |只看该作者
我实在无法理解为什么pm一直执着于 “节省一个局部变量”,之前批小乔的时候也是:
  1. xx printxx(struct st * head, ...)
  2. {
  3.     struct st * node = head;

  4.     for ()
  5.         node....
  6. }
复制代码
他就痛批node不应该声明。

在这个贴里面,依然“节省一个局部变量”,而用head进行迭代。用head迭代本来就违背了head的意思。太执着了~~~~~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP