当前位置: 首页 > news >正文

folly之侵入式链表

侵入式链表

侵入式链表(Intrusive Linked List)是一种数据结构,它的节点不是通过包含链表节点的对象来实现的(像非侵入式链表那样),而是通过在节点对象中直接包含指向其他节点的指针来实现的。这意味着链表节点对象本身需要被修改以包含指向链表其他部分的指针。

直接上代码

template <class T>
struct AtomicIntrusiveLinkedListHook {T* next{nullptr};
};template <class T, AtomicIntrusiveLinkedListHook<T> T::*HookMember>
class AtomicIntrusiveLinkedList {public:AtomicIntrusiveLinkedList() {}AtomicIntrusiveLinkedList(const AtomicIntrusiveLinkedList&) = delete;AtomicIntrusiveLinkedList& operator=(const AtomicIntrusiveLinkedList&) =delete;AtomicIntrusiveLinkedList(AtomicIntrusiveLinkedList&& other) noexcept {auto tmp = other.head_.load();other.head_ = head_.load();head_ = tmp;}AtomicIntrusiveLinkedList& operator=(AtomicIntrusiveLinkedList&& other) noexcept {auto tmp = other.head_.load();other.head_ = head_.load();head_ = tmp;return *this;}~AtomicIntrusiveLinkedList() {assert(empty());}bool empty() const {return head_.load() == nullptr;}bool insertHead(T* t) {assert(next(t) == nullptr);auto oldHead = head_.load(std::memory_order_relaxed);do {next(t) = oldHead;} while (!head_.compare_exchange_weak(oldHead, t,std::memory_order_release,std::memory_order_relaxed));return oldHead == nullptr;}template <typename F>bool swee
http://www.lryc.cn/news/503551.html

相关文章:

  • GPT-5 训练遇阻:预期目标难达成与交付延期的深度剖析
  • C缺陷与陷阱 — 3 深入理解表达式
  • Linux常用指令-----中
  • k8s 部署方式kustomization和helm的区别
  • Alogrithm:骑士走棋盘
  • Oracle 与 达梦 数据库 对比
  • [COLM 2024] V-STaR: Training Verifiers for Self-Taught Reasoners
  • 【Python】使用Selenium的find_element模块获取网页上的大段文字和表格的方法(建议收藏!)
  • 蓝桥杯刷题——day4
  • 内网是如何访问到互联网(H3C源NAT)
  • 源码分析之Openlayers中的Zoom缩放控件
  • k8s的ConfigMap是什么, 为什么设计ConfigMap, 如何使用ConfigMap
  • fiddler设置抓取https,还抓取不到https如何解决?
  • Python高性能web框架-FastApi教程:(1)创建一个简单的FastApi
  • Django基础之模板
  • RabbitMQ Work Queues (工作队列模式) 使用案例
  • C#高级:Winform桌面开发中TreeView的基础例子
  • 大模型的文件有哪些?
  • QT 国际化(翻译)
  • C 进阶 — 指针的使用
  • 【经验分享】容器云运维的知识点
  • MFC学习笔记专栏开篇语
  • 电子科技大学《高级算法设计与分析》期末复习问题汇总(客观题-选择题、判断题)
  • GPTcelltype——scRNA-seq注释
  • AI与大数据的深度结合:驱动决策的革命性力量
  • Java多线程与线程池技术详解(九)
  • 【常考前端面试题总结】---2025
  • 什么是大语言模型(LLM)
  • 柚坛工具箱Uotan Toolbox适配鸿蒙,刷机体验再升级
  • supervisor使用详解