
链表
std::list是双向链表,支持O(1)任意位置增删但不支持随机访问;初始化方式多样,操作依赖迭代器,提供splice、merge、sort等高效特有方法。
MySQL中说的“B树索引”实际是B+树索引,因B+树所有数据存于叶子节点、叶子间有双向链表、查询路径固定,更适配磁盘I/O与范围查询;主键索引叶子存整行,二级索引叶子存列值+主键,需回表;函数、隐式...
new/delete在高频小对象场景变慢,因频繁系统调用、堆管理器锁竞争与内存碎片;内存池通过预分配大块内存+原子空闲链表实现无锁高效分配。
反转单向链表的核心是逐个改变节点next指针指向,需用三指针(prev、curr、next_temp)保存上下文,循环中先暂存curr->next再修改curr->next=prev,最后...
Go双向链表需用prev/next指针维护前后关系,插入删除必须同步更新两侧指针;节点与链表结构中指针初始为nil防panic;头插、尾插、删节点均需分空链表与非空情况处理头尾指针及连接关系。
Go中“内存高效”指用指针避免数据复制、复用实例、减轻GC压力;栈用[]*T存指针,队列用环形缓冲区+指针赋值;小数据传值更优,大数据或需修改时用指针;优先使用标准库,必要时再定制。
使用std::list::reverse可直接反转双向链表;手动反转单链表常用三指针迭代法或递归法,前者时间O(n)空间O(1),后者简洁但占栈空间。
缓存友好代码的核心是提升CPU对高速缓存的利用率,关键在于数据布局与访问模式匹配硬件特性:注重局部性、对齐、预取友好及避免伪共享;优先使用连续结构如vector而非链表,合理设计结构体大小与成员顺序,...
Go标准库container/ring不适合高效线程安全环形队列,因其是单向循环链表而非数组-backed缓冲区;推荐用切片+双索引或第三方库实现。
需自定义内存分配器以规避系统堆的锁开销与碎片问题,提升高频小对象分配性能;简易定长池用预分配+自由链表实现O(1)分配;多尺寸池仿slab分层管理;集成标准容器需满足分配器规范并确保异常安全。