list_for_each()与list_for_each_safe()
#define list_for_each(pos, head) \
for (pos = (head)->next; prefetch(pos->next), pos != (head); \
pos = pos->next)
由定義可知,list_del(pos)(將pos的前后指針指向undefined state)panic,list_del_init(pos)(將pos前后指針指向自身)導致死循環。
#define list_for_each_safe(pos, n, head) \
for (pos = (head)->next, n = pos->next; pos != (head); \
pos = n, n = pos->next)
由定義可知,safe函數首先將pos的后指針緩存到n,處理一個流程后再賦回pos,避免了這種情況的發生。
因此只遍歷鏈表不刪除節點時可以使用前者,若有刪除節點的操作,則要使用后者。
由safe的說明可知,是專門為刪除節點時準備的:iterate over a list safe against removal of list entry。
其他帶safe的處理也基本源于這個原因。
轉載于:https://blog.51cto.com/charlesxie/721334
總結
以上是生活随笔為你收集整理的list_for_each()与list_for_each_safe()的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 学院派CAD工具箱及CAD调用外部应用程
- 下一篇: .net中下载文件的方法