java并發(fā)編程概念

原子性

原子是世界上的最小單位朽砰,具有不可分割性悲立。比如 a=0捺萌;(a非long和double類型) 這個(gè)操作是不可分割的档冬,那么我們說(shuō)這個(gè)操作時(shí)原子操作膘茎。再比如:a++; 這個(gè)操作實(shí)際是a = a + 1酷誓;是可分割的披坏,所以他不是一個(gè)原子操作。非原子操作都會(huì)存在線程安全問(wèn)題盐数,需要我們使用同步技術(shù)(sychronized)來(lái)讓它變成一個(gè)原子操作棒拂。一個(gè)操作是原子操作,那么我們稱它具有原子性玫氢。java的concurrent包下提供了一些原子類帚屉,我們可以通過(guò)閱讀API來(lái)了解這些原子類的用法。比如:AtomicInteger漾峡、AtomicLong攻旦、AtomicReference


可見(jiàn)性

可見(jiàn)性,是指線程之間的可見(jiàn)性生逸,一個(gè)線程修改的狀態(tài)對(duì)另一個(gè)線程是可見(jiàn)的牢屋。也就是一個(gè)線程修改的結(jié)果。另一個(gè)線程馬上就能看到槽袄。比如:用volatile修飾的變量烙无,就會(huì)具有可見(jiàn)性。volatile修飾的變量不允許線程內(nèi)部緩存和重排序遍尺,即直接修改內(nèi)存截酷。所以對(duì)其他線程是可見(jiàn)的。但是這里需要注意一個(gè)問(wèn)題狮鸭,volatile只能讓被他修飾內(nèi)容具有可見(jiàn)性合搅,但不能保證它具有原子性。比如 volatile int a = 0歧蕉;之后有一個(gè)操作 a++灾部;這個(gè)變量a具有可見(jiàn)性,但是a++ 依然是一個(gè)非原子操作惯退,也就這這個(gè)操作同樣存在線程安全問(wèn)題赌髓。


對(duì)于非volatile類型的double和long變量,jvm允許將64位分解為兩個(gè)32位的操作催跪,如果讀取一個(gè)非volatile類型的變量時(shí)锁蠕,如果對(duì)該變量的讀操作和寫操作不在同一個(gè)線程中執(zhí)行,那么可能會(huì)讀到的某個(gè)值的高32位和另一個(gè)值的低32位懊蒸。

對(duì)象的發(fā)布與逸出

“發(fā)布(Publish)“一個(gè)對(duì)象是指使對(duì)象能夠在當(dāng)前作用域之外的代碼中使用荣倾。可以通過(guò) 公有靜態(tài)變量骑丸,非私有方法舌仍,構(gòu)造方法內(nèi)隱含引用 三種方式妒貌。

如果對(duì)象構(gòu)造完成之前就發(fā)布該對(duì)象,就會(huì)破壞線程安全性铸豁。當(dāng)某個(gè)不應(yīng)該發(fā)布的對(duì)象被發(fā)布時(shí)灌曙,這種情況就被稱為逸出(Escape)。

  • 公有靜態(tài)變量
public static Set<string> mySet;  
   public void initialize() {
        mySet = new HashSet<string>();
    }

當(dāng)發(fā)布某個(gè)對(duì)象時(shí)节芥,可能會(huì)間接地發(fā)布其他對(duì)象在刺。如果將一個(gè) String 對(duì)象添加到集合 mySet 中,那么同樣會(huì)發(fā)布這個(gè)對(duì)象头镊,因?yàn)槿魏未a都可以遍歷這個(gè)集合蚣驼,并獲得對(duì)這個(gè) String 對(duì)象的引用,然后就可以修改String對(duì)象。

  • 非私有方法
class UnsafeState {
    private String[] states = new String[] { "AK", "AL" };
 
    public String[] getStates() {
        return states;
    }
}

如果按照上訴方法來(lái)發(fā)布 states拧晕,就會(huì)出問(wèn)題隙姿,因?yàn)槿魏握{(diào)用者都能修改這個(gè)數(shù)組的內(nèi)容。數(shù)組 states 已經(jīng)溢出了它所在的作用域了厂捞,因?yàn)檫@個(gè)本應(yīng)是私有的變量已經(jīng)被發(fā)布了输玷。當(dāng)私有變量被發(fā)布出去之后,這個(gè)類就無(wú)法知道”外部方法“會(huì)進(jìn)行何種操作.例如:

  String[] states = getStates();
  states[0] = "bk";

這樣就修改了這個(gè)數(shù)組里面的對(duì)象靡馁。如果是多線程的話 states在多線程中應(yīng)用執(zhí)行欲鹏,就會(huì)有風(fēng)險(xiǎn)。

  • 構(gòu)造方法內(nèi)隱含引用
public class ThisEscape {
    public ThisEscape(EventSource source) {
        source.registerListener(new EventListener() {
            public void onEvent(Event e) {
                doSomething(e);
            }
        });
    }
}

這種在構(gòu)造函數(shù)里面啟用線程是不對(duì)的臭墨。

public class SafeListener{
    private final EventListener listener;
    private SafeListener(){
        listener = new EventListener(){
            public void onEvent(Event e){
                doSomething(e);
            }
        };
    }
    public static SafeListener newInstance(EventSource source){
        SafeListener safe = new SafeListener();
        source.registerListener(safe.listener);
        return safe;
    }
}

線程封閉

當(dāng)訪問(wèn)共享的可變數(shù)據(jù)時(shí)赔嚎,通常需要使用同步。一種避免使用同步的方式就是不共享數(shù)據(jù)胧弛。如果僅在單線程內(nèi)訪問(wèn)數(shù)據(jù)尤误,就不需要同步。這種技術(shù)被稱為線程封閉(Thread Confinement)结缚,它是實(shí)現(xiàn)線程安全型的最簡(jiǎn)單方式之一损晤。當(dāng)某個(gè)對(duì)象封閉在一個(gè)線程中時(shí),這種用法將自動(dòng)實(shí)現(xiàn)線程安全性红竭,即使被封閉的對(duì)象本身不是線程安全的尤勋。
線程封閉的一種常見(jiàn)的應(yīng)用是 JDBC 的 Connection 對(duì)象。JDBC 規(guī)范并不要求 Connection 對(duì)象必須是線程安全的茵宪。在典型的服務(wù)器應(yīng)用程序中最冰,線程從連接池中獲得一個(gè) Connection 對(duì)象,并且用該對(duì)象來(lái)處理請(qǐng)求稀火,使用完之后再將對(duì)象返還給連接池暖哨。由于大多數(shù)請(qǐng)求(例如 Servlet 請(qǐng)求或 EJB 調(diào)用等)都是由單個(gè)線程采用同步的方式來(lái)處理,并且在 Connection 對(duì)象返回之前凰狞,連接池都不會(huì)將它分配給其它線程鹿蜀,因此箕慧,這種連接管理模式在處理請(qǐng)求時(shí)隱含的將 Connection 對(duì)象封閉在線程中服球。
Java 語(yǔ)言及其核心庫(kù)提供了一些機(jī)制來(lái)幫助維持線程封閉性茴恰,例如局部變量和 ThreadLocal 類,即便如此斩熊,程序員仍然需要確保封閉在線程中的對(duì)象不會(huì)從線程中逸出往枣。

ThreadLocal是解決線程安全問(wèn)題一個(gè)很好的思路,它通過(guò)為每個(gè)線程提供一個(gè)獨(dú)立的變量副本解決了變量并發(fā)訪問(wèn)的沖突問(wèn)題粉渠。在很多情況下分冈,ThreadLocal比直接使用synchronized同步機(jī)制解決線程安全問(wèn)題更簡(jiǎn)單,更方便霸株,且結(jié)果程序擁有更高的并發(fā)性雕沉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市去件,隨后出現(xiàn)的幾起案子坡椒,更是在濱河造成了極大的恐慌,老刑警劉巖尤溜,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件倔叼,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡宫莱,警方通過(guò)查閱死者的電腦和手機(jī)丈攒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)授霸,“玉大人巡验,你說(shuō)我怎么就攤上這事〉舛” “怎么了显设?”我有些...
    開(kāi)封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)藏畅。 經(jīng)常有香客問(wèn)我敷硅,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任比默,我火速辦了婚禮氮发,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘幽七。我一直安慰自己,他們只是感情好溅呢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布澡屡。 她就那樣靜靜地躺著猿挚,像睡著了一般。 火紅的嫁衣襯著肌膚如雪驶鹉。 梳的紋絲不亂的頭發(fā)上绩蜻,一...
    開(kāi)封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音室埋,去河邊找鬼办绝。 笑死,一個(gè)胖子當(dāng)著我的面吹牛姚淆,可吹牛的內(nèi)容都是我干的孕蝉。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼腌逢,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼降淮!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起搏讶,我...
    開(kāi)封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤佳鳖,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后窍蓝,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體腋颠,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年吓笙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了淑玫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡面睛,死狀恐怖絮蒿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情叁鉴,我是刑警寧澤土涝,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站幌墓,受9級(jí)特大地震影響但壮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜常侣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一蜡饵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胳施,春花似錦溯祸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)博杖。三九已至,卻和暖如春筷登,著一層夾襖步出監(jiān)牢的瞬間剃根,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工仆抵, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留跟继,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓镣丑,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親娱两。 傳聞我的和親對(duì)象是個(gè)殘疾皇子莺匠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容