1.list_for_each_entry宏的定義
[cpp]
#define list_for_each_entry(pos, head, member) \
for (pos = list_entry((head)->next, typeof(*pos), member); \
prefetch(pos->member.next), &pos->member != (head); \
pos = list_entry(pos->member.next, typeof(*pos), member))
2.輔助宏list_for_each和list_entry的定義
list_for_each
[cpp]
#define list_for_each(pos, head) \
for (pos = (head)->next; prefetch(pos->next), pos != (head); pos = pos->next)
list_entry
[cpp]
#define list_entry(ptr, type, member) \
container_of(ptr, type, member)
3.分解宏
[cpp]
分解:list_for_each_entry(pos, head, member)-->
for (
pos = container_of((head)->next, typeof(*pos), member); //指針賦值
pos->member.next, &pos->member != (head); //指向的對象不是head,也就是鏈表沒到尾部
pos = container_of(pos->member.next, typeof(*pos), member) //指向下一個pos對象
)
prefetch可以不考慮,用於預取以提高遍歷速度
這裡的關系是pos是個結構體,member是它的成員,pos作為for循環的循環因子,遍歷整個head鏈表,中的member對象
下面的圖中member就是list_head,他有兩個成員next和prev
list_for_each_entry的作用便是根據含有list(member)的結構體指針pos,list(member)的鏈表頭,及pos的成員list(member)
從頭head跟蹤圖片箭頭,根據member找到對應的pos,目的在對for循環體中找到的pos的其他成員做操作,
例如
list_for_each_entry(pos, head, member)
pos->a=10;
這個例子是吧圖中鏈表pos1~7中的成員對象a賦值為10;