C语言双向循环链表
http://androidxref.com/6.0.0_r1/xref/system/core/include/cutils/list.h
struct listnode
{
struct listnode *next;
struct listnode *prev;
};
static inline void list_init(struct listnode *node) { node->next = node; node->prev = node; } static inline void list_add_tail(struct listnode *head, struct listnode *item) { item->next = head; item->prev = head->prev; head->prev->next = item; head->prev = item; } static inline void list_add_head(struct listnode *head, struct listnode *item) { item->next = head->next; item->prev = head; head->next->prev = item; head->next = item; } static inline void list_remove(struct listnode *item) { item->next->prev = item->prev; item->prev->next = item->next; }
双向循环链表
初始化: 一个节点,前向节点和后向节点都指向自己。
list_add_head 把节点加到head的后面(这里是这么实现的,没有规定说链表一定要有顺序,除非有特殊需要)
list_add_tail 在节点加到head的前面(实际上也就是循环双向链表的结尾)
不管做什么操作 head始终作为第一个节点。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架