共計 954 個字符,預計需要花費 3 分鐘才能閱讀完成。
樂觀鎖是一種樂觀地認為并發訪問不會發生沖突的鎖機制,它適用于讀多寫少的場景。在 Java 中,可以使用 AtomicInteger 類來實現樂觀鎖。
下面是一個簡單的示例代碼,演示了如何使用樂觀鎖實現多線程并發訪問共享變量的功能:
import java.util.concurrent.atomic.AtomicInteger;
public class OptimisticLockExample {private static AtomicInteger counter = new AtomicInteger(0);
public static void main(String[] args) {Thread thread1 = new Thread(new IncrementTask());
Thread thread2 = new Thread(new IncrementTask());
thread1.start();
thread2.start();
try {// 等待線程執行完成
thread1.join();
thread2.join();} catch (InterruptedException e) {e.printStackTrace();
}
System.out.println("Counter: " + counter);
}
static class IncrementTask implements Runnable {@Override
public void run() {int oldValue, newValue;
do {oldValue = counter.get();
newValue = oldValue + 1;
} while (!counter.compareAndSet(oldValue, newValue));
}
}
}
在上面的代碼中,我們使用 AtomicInteger 類來定義一個共享變量 counter。在每個線程的 run 方法中,我們通過循環讀取和更新 counter 的值,直到成功執行 compareAndSet 方法將新值寫入 counter 中。這樣可以確保多個線程并發修改 counter 時不會出現沖突。
需要注意的是,樂觀鎖適用于讀多寫少的場景,如果并發寫操作非常頻繁,樂觀鎖的性能可能會受到影響。在這種情況下,可以考慮使用悲觀鎖來保證數據的一致性。
丸趣 TV 網 – 提供最優質的資源集合!
正文完