首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >ptmalloc_lock_all奇怪的for循环

ptmalloc_lock_all奇怪的for循环
EN

Stack Overflow用户
提问于 2019-03-15 06:22:44
回答 1查看 46关注 0票数 1

我正在尝试理解glibc中的一些代码。为什么要使用这个奇怪的for循环呢?我猜是出于某种原因进行编译器优化吧?

代码语言:javascript
复制
 237   for (ar_ptr = &main_arena;; )
 238     { 
 239       (void) mutex_lock (&ar_ptr->mutex);
 240       ar_ptr = ar_ptr->next;
 241       if (ar_ptr == &main_arena)
 242         break;
 243     }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-03-15 07:55:51

你在那个循环中发现了什么奇怪的东西?

显然,main_arena是循环链表的头部。要遍历循环列表,您可以沿着下面的链接,直到您发现自己回到了开头。但您必须在循环结束时执行该测试,因为退出条件在第一次迭代时为真。

循环链表非常常见,特别是在双向链表中。使列表循环可以避免对insert和delete操作进行大量特殊情况检查。

在本例中,每个列表项中都有一个互斥锁,循环的目的是锁定所有互斥锁。这可能就是该函数被称为lock_all的原因。

您可以使用do ... while编写经过最终测试的循环,但是该构造不提供初始化循环变量的方法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55172898

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档