成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

淺談Java并發(fā)編程系列(一)—— 如何保證線程安全

mylxsw / 1481人閱讀

摘要:比如需要用多線程或分布式集群統(tǒng)計一堆用戶的相關(guān)統(tǒng)計值,由于用戶的統(tǒng)計值是共享數(shù)據(jù),因此需要保證線程安全。如果類是無狀態(tài)的,那它永遠是線程安全的。參考探索并發(fā)編程二寫線程安全的代碼

線程安全類 保證類線程安全的措施:

不共享線程間的變量;

設(shè)置屬性變量為不可變變量;

每個共享的可變變量都使用一個確定的鎖保護;

保證線程安全的思路: 1. 通過架構(gòu)設(shè)計

通過上層的架構(gòu)設(shè)計和業(yè)務(wù)分析來避免并發(fā)場景。比如需要用多線程或分布式集群統(tǒng)計一堆用戶的相關(guān)統(tǒng)計值,由于用戶的統(tǒng)計值是共享數(shù)據(jù),因此需要保證線程安全。從業(yè)務(wù)上分析出用戶之間的數(shù)據(jù)并不共享,因此可以設(shè)計一個規(guī)則來保證一個用戶的計算工作和數(shù)據(jù)訪問只被一個線程或一臺機器完成,這樣從設(shè)計上避免了接下來可能的并發(fā)問題。

2. 保證類無狀態(tài)

有狀態(tài)會限制橫向擴展能力,也可能產(chǎn)生并發(fā)問題。如果類是無狀態(tài)的,那它永遠是線程安全的。因此在設(shè)計階段盡可能用無狀態(tài)的類來滿足業(yè)務(wù)需求。

3. 區(qū)別原子操作和復合操作

常見的復合操作包括check-then-act, i++等。雖然check-then-act從表面上看很簡單,但卻普遍存在與我們?nèi)粘5拈_發(fā)中,特別是在數(shù)據(jù)庫存取這一塊。比如我們需要在數(shù)據(jù)庫里存一個客戶的統(tǒng)計值,當統(tǒng)計值不存在時初始化,當存在時就去更新。如果不把這組邏輯設(shè)計為原子性的就很有可能產(chǎn)生出兩條這個客戶的統(tǒng)計值。
在單機環(huán)境下處理這個問題還算容易,通過鎖或者同步來把這組復合操作變?yōu)樵硬僮鳎诜植际江h(huán)境下就不適用了。一般情況下是通過在數(shù)據(jù)庫端做文章,比如通過唯一性索引或者悲觀鎖來保障其數(shù)據(jù)一致性。當然任何方案都是有代價的,這就需要具體情況下來權(quán)衡。

4. 鎖

使用鎖應(yīng)注意:

每個共享變量必須由一個確定的鎖保護。

使用鎖會有性能損失

鎖不能解決在分布式環(huán)境共享變量的并發(fā)問題。

參考:探索并發(fā)編程(二)------寫線程安全的Java代碼

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65162.html

相關(guān)文章

  • 淺談Java并發(fā)編程系列(六) —— 線程池的使用

    摘要:線程池的作用降低資源消耗。通過重復利用已創(chuàng)建的線程降低線程創(chuàng)建和銷毀造成的資源浪費。而高位的部分,位表示線程池的狀態(tài)。當線程池中的線程數(shù)達到后,就會把到達的任務(wù)放到中去線程池的最大長度。默認情況下,只有當線程池中的線程數(shù)大于時,才起作用。 線程池的作用 降低資源消耗。通過重復利用已創(chuàng)建的線程降低線程創(chuàng)建和銷毀造成的資源浪費。 提高響應(yīng)速度。當任務(wù)到達時,不需要等到線程創(chuàng)建就能立即執(zhí)行...

    Vicky 評論0 收藏0
  • 淺談Java并發(fā)編程系列(二)—— Java內(nèi)存模型

    摘要:物理計算機并發(fā)問題在介紹內(nèi)存模型之前,先簡單了解下物理計算機中的并發(fā)問題?;诟咚倬彺娴拇鎯换ヒ胍粋€新的問題緩存一致性。寫入作用于主內(nèi)存變量,把操作從工作內(nèi)存中得到的變量值放入主內(nèi)存的變量中。 物理計算機并發(fā)問題 在介紹Java內(nèi)存模型之前,先簡單了解下物理計算機中的并發(fā)問題。由于處理器的與存儲設(shè)置的運算速度有幾個數(shù)量級的差距,所以現(xiàn)代計算機加入一層讀寫速度盡可能接近處理器的高速緩...

    Edison 評論0 收藏0
  • 淺談java中的并發(fā)控制

    摘要:并發(fā)需要解決的問題功能性問題線程同步面臨兩個問題,想象下有兩個線程在協(xié)作工作完成某項任務(wù)。鎖可用于規(guī)定一個臨界區(qū),同一時間臨界區(qū)內(nèi)僅能由一個線程訪問。并發(fā)的數(shù)據(jù)結(jié)構(gòu)線程安全的容器,如等。 并發(fā)指在宏觀上的同一時間內(nèi)同時執(zhí)行多個任務(wù)。為了滿足這一需求,現(xiàn)代的操作系統(tǒng)都抽象出 線程 的概念,供上層應(yīng)用使用。 這篇博文不打算詳細展開分析,而是對java并發(fā)中的概念和工具做一個梳理。沿著并發(fā)模...

    Gilbertat 評論0 收藏0
  • 淺談Java并發(fā)編程系列(四)—— 原子性、可見性與有序性

    摘要:內(nèi)存模型是圍繞著在并發(fā)過程中如何處理原子性可見性和有序性這個特征來建立的,我們來看下哪些操作實現(xiàn)了這個特性??梢娦钥梢娦允侵府斠粋€線程修改了共享變量的值,其他線程能夠立即得知這個修改。 Java內(nèi)存模型是圍繞著在并發(fā)過程中如何處理原子性、可見性和有序性這3個特征來建立的,我們來看下哪些操作實現(xiàn)了這3個特性。 原子性(atomicity): 由Java內(nèi)存模型來直接保證原子性變量操作包括...

    tianren124 評論0 收藏0
  • 淺談Java并發(fā)編程系列(三)—— volatile型變量

    摘要:禁止指令重排序優(yōu)化。只有當線程對變量執(zhí)行的前一個動作是時,才能對執(zhí)行動作并且,只有當對變量執(zhí)行的后一個動作是時,線程才能對變量執(zhí)行動作。變量不需要與其他的狀態(tài)變量共同參與不變約束。在某些情況下,的同步機制性要優(yōu)于鎖。 當一個變量定義為volatile之后,它具備兩種特性: 保證此變量對所有線程的可見性,這里的可見性是指當一條線程修改了這個變量的值,新值對于其他線程來說是可以立即得知的...

    zxhaaa 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<