溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解java 并發(fā)中的原子性與可視性

發(fā)布時間:2020-11-26 15:53:55 來源:億速云 閱讀:153 作者:Leah 欄目:編程語言

如何理解java 并發(fā)中的原子性與可視性?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

java 并發(fā)中的原子性與可視性實例詳解

并發(fā)其實是一種解耦合的策略,它幫助我們把做什么(目標)和什么時候做(時機)分開。這樣做可以明顯改進應用程序的吞吐量(獲得更多的CPU調度時間)和結構(程序有多個部分在協(xié)同工作)。做過java Web開發(fā)的人都知道,Java Web中的Servlet程序在Servlet容器的支持下采用單實例多線程的工作模式,Servlet容器為你處理了并發(fā)問題。

原子性

原子是世界上的最小單位,具有不可分割性。比如 a=0;(a非long和double類型) 這個操作是不可分割的,那么我們說這個操作時原子操作。再比如:a++; 這個操作實際是a = a + 1;是可分割的,所以他不是一個原子操作。非原子操作都會存在線程安全問題,需要我們使用同步技術(sychronized)來讓它變成一個原子操作。一個操作是原子操作,那么我們稱它具有原子性。Java的concurrent包下提供了一些原子類,我們可以通過閱讀API來了解這些原子類的用法。比如:AtomicInteger、AtomicLong、AtomicReference等。

可見性

可見性,是指線程之間的可見性,一個線程修改的狀態(tài)對另一個線程是可見的。也就是一個線程修改的結果。另一個線程馬上就能看到。比如:用volatile修飾的變量,就會具有可見性。volatile修飾的變量不允許線程內(nèi)部緩存和重排序,即直接修改內(nèi)存。所以對其他線程是可見的。但是這里需要注意一個問題,volatile只能讓被他修飾內(nèi)容具有可見性,但不能保證它具有原子性。比如 volatile int a = 0;之后有一個操作 a++;這個變量a具有可見性,但是a++ 依然是一個非原子操作,也就這這個操作同樣存在線程安全問題。

他們之間關系

原子性是說一個操作是否可分割。可見性是說操作結果其他線程是否可見。這么看來他們其實沒有什么關系。

實例

package com.chu.test.thread; 
/** 
 * 可見性分析 
 * @author Administrator 
 * 
 *volatile 會拒絕編譯器對其修飾的變量進行優(yōu)化。也就不會存在重排序的問題。volatile只會影響可見性,不會影響原子性。 
 *下面程序如果不加 
 */ 
public class Test { 
 
 volatile int a = 1; 
 volatile boolean ready; 
  
 public class PrintA extends Thread{ 
  @Override 
  public void run() { 
   while(!ready){ 
    Thread.yield(); 
   } 
   System.out.println(a); 
  } 
 } 
 public static void main(String[] args) throws InterruptedException { 
  Test t = new Test(); 
  t.new PrintA().start(); 
  //下面兩行如果不加volatile的話,執(zhí)行的先后順序是不可預測的。并且下面兩行都是原子操作,但是這兩行作為一個整體的話就不是一個原子操作。 
  t.a = 48; //這是一個原子操作,但是其結果不一定具有可見性。加上volatile后就具備了可見性。 
  t.ready = true;//同理 
 } 
 
}

關于如何理解java 并發(fā)中的原子性與可視性問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業(yè)資訊頻道了解更多相關知識。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI