IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Disruptor

共 2 篇相关文章

IT 累计浏览 5,549

写Java也得了解CPU缓存

这篇讲的是,为什么像Java这样的高级语言开发者,也不能忽视底层的CPU缓存。作者从LMAX Disruptor框架和马丁关于“机械同理心”的博文出发,打破了“只有C/C++才需要懂CPU”的常规认知。 文章重点解析了CPU的三级缓存(L1/L2/L3)结构,并通过具体数据对比了各层级与CPU核心、内存之间的访问延迟差异,直观展现了数据局部性的重要性。作者还通过一段Java数组遍历代码的对比,生动演示了缓存行(Cache Line)的影响:符合内存访问顺序的循环,比按列访问的性能快了近70倍。这背后的原因,正是前者能高效利用单次缓存行加载的数据块,而后者则导致了大量不必要的缓存失效。 最终,文章梳理了导致缓存失效的三种常见情况(首次访问、冲突、缓存满),为优化程序性能指明了方向。这提醒我们,即使编写Java应用,理解硬件行为也能解锁显著的性能潜力。

IT 累计浏览 12,097

一种高效无锁内存队列的实现

这篇讲的是LMAX公司开源的高性能内存队列Disruptor的实现原理。作者从设计文档和实践博客出发,梳理了这个被称作“最快队列”的核心设计思想。 Disruptor要解决的是高并发场景下传统队列带来的锁竞争、伪共享和频繁垃圾回收问题。它的核心方案围绕一个环形缓冲区展开,通过预分配固定大小的数组作为存储,避免了动态内存分配的开销。最关键的是,整个读写操作都通过CAS指令实现无锁化,用序列号代替锁来协调多生产者与多消费者。 文章分析了其巧妙之处:利用缓存行填充消除伪共享,采用双缓冲思想优化写入,并允许消费者独立消费,这些设计共同实现了极低的延迟和极高的吞吐量。作者在总结中对比了它与传统并发队列的适用场景,指出Disruptor更适合对延迟敏感、数据处理量巨大的系统核心链路。