java - volatile 能否解決線程共享數據的安全。
問題描述
比如說我要寫一個單例模式 不用sycrynized同步方法 用volitile修飾
private Sigleton(){}
private static volitile Sigleton s = null;
public static Sigleton getInstance(){
if (s==null){ s= new Singleton(); } return s;
}
這樣能不能解決線程安全問題。
怎么理解線程可見性
如果我兩個線程同時都進來 if s==null 最后還不是new出兩個sigleton對象嗎?
問題解答
回答1:如果new的開銷很小的話,你這樣寫完全沒問題。但如果初始化開銷很大,那還是得用 synchronized 。典型的 雙檢查鎖 是這樣寫的:
private Singleton() {}private static volitile Singleton s = null;public static Singleton getInstance() { if (s == null) {synchronized (Singleton.class) { if (s == null) {s = new Singleton(); }} } return s;}回答2:
怎么理解線程可見性
先理解內存模型。
線程并不直接修改主內存中的變量,而是先寫自己的工作內存,然后再同步到主內存中,如果還沒同步,其他的線程是看不到修改的(他們還是看到自己的工作內存的緩存)。
相關文章:
1. mysql - 記得以前在哪里看過一個估算時間的網站2. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””3. docker-compose中volumes的問題4. angular.js - angular內容過長展開收起效果5. dockerfile - 為什么docker容器啟動不了?6. macos - mac下docker如何設置代理7. docker鏡像push報錯8. javascript - 能否讓vue-cli的express修改express重啟服務9. docker綁定了nginx端口 外部訪問不到10. 為什么我ping不通我的docker容器呢???
