免费注册 查看新帖 |

Chinaunix

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

链表中使用二重指针的优点有什么 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-06-21 20:24 |只看该作者 |倒序浏览
看有些链表中定义的item,并非使用 *next, *prev,

而是向前指针使用二重指针

类似如下这种:
struct QUEUE_ITEM *tqe_next;      
struct QUEUE_ITEM **tqe_prev;  

请问这样做有什么好处吗,感觉跟直接使用*prev没什么区别,想不太明白

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
2 [报告]
发表于 2011-06-21 22:28 |只看该作者
这种指针通常用法是用
father->tqe_next = this;
this->tqe_prev = &father->tqe_next;
用于对结点指针的修改。

论坛徽章:
0
3 [报告]
发表于 2011-06-21 23:10 |只看该作者
本帖最后由 aomw10 于 2011-06-21 23:26 编辑
这种指针通常用法是用
father->tqe_next = this;
this->tqe_prev = &father->tqe_next;
用于对结点指针的 ...
cobras 发表于 2011-06-21 22:28



   谢谢,知道是这么用,但关键是这里用二重指针有什么好处?

   在每个item中定义一个向前指针和向后指针不是一样用吗,为什么向前指针要定义为二重指针

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
4 [报告]
发表于 2011-06-22 08:32 |只看该作者
您想想,这样后您还能修改父结点的内容吗?即可以自由插入,删除,又不会暴露父结点,……

论坛徽章:
0
5 [报告]
发表于 2011-06-22 10:39 |只看该作者
楼上说的很好,还有其他的好处吗?

论坛徽章:
0
6 [报告]
发表于 2011-06-22 11:11 |只看该作者
之所以要使用二级指针,主要就是要修改一级指针的内容。讲明白了就这么回事。如果不要修改一级指针的内容,何必用那坑爹的二级指针折腾呢?

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
7 [报告]
发表于 2011-06-22 11:36 |只看该作者
当然这种说法只是相对的。不能直接访问父结点的内容,但可以通过其它方式获得父结点。
father = (struct node_t *)((char *)*this->prev_node - offsetof(struct node_t, next_node));
只是复杂点。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
8 [报告]
发表于 2011-06-23 14:09 |只看该作者
看有些链表中定义的item,并非使用 *next, *prev,

而是向前指针使用二重指针

类似如下这种:
struct ...
aomw10 发表于 2011-06-21 20:24



    没有优点,需要而已。

论坛徽章:
0
9 [报告]
发表于 2011-06-23 14:36 |只看该作者
回复 1# aomw10


    使用二级指针,很方便就修改了传入的结点一级指针的值啊。

    如果用一级指针,则只能通过指针修改指针所指内容,却无法修改指针的值,也就是指针所指的内存块。

    在很多数据结构实现中,都会采用二级指针作为一个参数传入到函数中,这样就可以在函数中方便的构造需要的数据结构。

    nginx中看到了4级指针,呵呵。

论坛徽章:
0
10 [报告]
发表于 2011-06-24 17:36 |只看该作者
回复  aomw10


    使用二级指针,很方便就修改了传入的结点一级指针的值啊。

    如果用一级指针 ...
zhanglistar 发表于 2011-06-23 14:36



    。。。谢谢解释,可惜解释的不是我的问题。。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP