一种常见的并发编程场景的处理
这篇讲的是并发编程中一个容易被忽略的典型场景:当一个“守护线程”提供共享资源,多个业务线程频繁读写,而主线程仅偶尔需要介入(比如统计数据、做快照)时,如何设计才能兼顾性能与数据安全? 文章指出,如果主线程和业务线程使用同一把锁(如 `synchronized`),在绝大多数(99.9%)主线程不介入的时间里,业务线程之间会产生不必要的锁竞争,拖累性能。作者给出的方案是引入 `AtomicBoolean` 和 `AtomicInteger` 两个原子变量(volatile 变量的实现)来协调状态:一个标志主线程是否正在独占操作,另一个统计当前正在写入的业务线程数。这样,业务线程只需在主线程介入时等待,而彼此之间几乎无需竞争锁,从而在大多数时间里实现近乎无锁的并发写入。 文章以 `ConcurrentHashMap` 为例给出了核心代码,并坦承在 Java 中这点性能差异或许可以忽略,且方案本身有一定复杂度。但作者认为,这种在“性能和数据保护之间寻求最大平衡”的设计思路,其实践意义是利大于弊的。