免费注册 查看新帖 |

Chinaunix

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

[C++] sgi stl源码的hash_table::resize,感觉有一行会导致循环引用,帮我看看 [复制链接]

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-11-30 19:03 |只看该作者 |倒序浏览
我在看hashtable的内部实现机制, 参考了一下侯捷的<STL源码剖析>,里面5.7.5当中,关于"重建表格"的一节,有下面的代码。
但是我感觉棕色方框处的代码会导致两个元素循环互指啊,大侠们看看:
  
给个解释吧

论坛徽章:
0
2 [报告]
发表于 2015-12-01 00:17 来自手机 |只看该作者
哈哈,看起来像,你自己画画图就发现不是。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
3 [报告]
发表于 2015-12-01 09:57 |只看该作者
yshwuxian 发表于 2015-12-01 00:17
哈哈,看起来像,你自己画画图就发现不是。

  1. first->next=tmp[new_bucket];
  2. tmp[new_bucket]=first;
复制代码
这两行之后岂不是tmp[new_bucket]->next=tmp[new_buckt],自己指向自己了?

论坛徽章:
0
4 [报告]
发表于 2015-12-01 10:47 |只看该作者
现在的tmp[new_bucket]->next=原先的tmp[new_bucket]

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
5 [报告]
发表于 2015-12-02 00:34 |只看该作者
本帖最后由 windoze 于 2015-12-02 00:34 编辑

回复 3# cdsfiui

外面不是还套着一个while么?

就像下面的代码,你觉得它会死循环吗?

  1. int x=a=0;
  2. while(a<100) {
  3.     // 一堆无关的代码
  4.     printf("%d", x);
  5.     x=a+1;
  6.     a=x;
  7.     // 一堆无关的代码
  8. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP