`@Contended` 是 Java 8 引入的一个注解,主要用于减少多线程环境下的伪共享(False Sharing)问题。伪共享是由于缓存行的争用导致的性能问题,特别是在多核处理器上。
### `@Contended` 注解的作用
- **减少伪共享**:当多个线程访问不同的变量,但这些变量位于同一个缓存行时,可能会引发伪共享问题。`@Contended` 注解通过在变量之间插入填充字段,确保它们位于不同的缓存行中,从而减少争用。
- **优化多线程性能**:在高并发场景下,使用 `@Contended` 可以显著提升性能,尤其是在频繁更新的状态变量上。
### 使用示例
```java
public class ContendedExample {
private long id;
@Contended
private volatile long counter1;
@Contended
private volatile long counter2;
public void incrementCounters() {
counter1++;
counter2++;
}
}
```
在这个例子中,`counter1` 和 `counter2` 被标记为 `@Contended`,这意味着编译器会在它们之间插入额外的填充字段,以确保它们不会位于同一缓存行中。
### 注意事项
- **适用场景**:`@Contended` 主要适用于高并发、多线程场景,特别是那些对性能要求极高的系统。
- **性能开销**:虽然 `@Contended` 可以减少伪共享,但它也会增加对象的内存占用,因为需要额外的填充字段。