1了解过什么是“伪共享”吗?
CPU缓存从内存读数据时,是按缓存行读取的,即使只用到一个变量,也要将整行数据进行读
取,这行数据量可能包含其他变量。当多个线程同时修改同一个缓存行里的不同变量时,由于
同时只能有一个线程在操作,所以相比将每个变量放到不同缓存行里,性能会有所下降。多个
线程同时修改了同一个缓存行上的不同变量,由于不能并发修改,所以称为“伪共享”。
2.“伪共享”出现的原因是什么?
因为CPU缓存和内存交换数据的单位是缓存行,而同一个缓存行里的多个变量不能同时被多个
线程修改。
3.如何避免“伪共享”?
- 字节填充(创建变量时,使用字段对其进行填充,避免多个变量被分派到同一个缓存行
里)。 - JDK8提供了一个Contended注解来解决伪共享。