@Contended

`@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` 可以减少伪共享,但它也会增加对象的内存占用,因为需要额外的填充字段。

你可能感兴趣的:(spring,java,后端)