在Java高并發下解決臟讀問題可以通過使用鎖機制或者使用線程安全的數據結構來實現。
示例使用synchronized關鍵字:
public class Data {
private String value;
public synchronized String getValue() {
return value;
}
public synchronized void setValue(String value) {
this.value = value;
}
}
示例使用ConcurrentHashMap:
import java.util.concurrent.ConcurrentHashMap;
public class Data {
private ConcurrentHashMap<String, String> map = new ConcurrentHashMap<>();
public String getValue(String key) {
return map.get(key);
}
public void setValue(String key, String value) {
map.put(key, value);
}
}
無論是使用鎖機制還是線程安全的數據結構,都可以解決Java高并發下的臟讀問題。具體選擇哪種方式取決于具體需求和場景。