轉:【Java並發編程】之八:多線程環境中安全使用集合API(含代碼)

來源:互聯網
上載者:User

標籤:comm   存在   java並發   ace   sorted   hash   多個   ase   java   

轉載請註明出處:http://blog.csdn.net/ns_code/article/details/17200509


    在集合API中,最初設計的Vector和Hashtable是多安全執行緒的。例如:對於Vector來說,用來添加和刪除元素的方法是同步的。如果只有一個線程與Vector的執行個體互動,那麼,要求擷取和釋放對象鎖便是一種浪費,另外在不必要的時候如果濫用同步化,也有可能會帶來死結。因此,對於更改集合內容的方法,沒有一個是同步化的。集合本質上是非多安全執行緒的,當多個線程與集合互動時,為了使它多安全執行緒,必須採取額外的措施。

     在Collections類 中有多個靜態方法,它們可以擷取通過同步方法封裝非同步集合而得到的集合:

     public static Collection synchronizedCollention(Collection c)

     public static List synchronizedList(list l)

     public static Map synchronizedMap(Map m)

     public static Set synchronizedSet(Set s)

     public static SortedMap synchronizedSortedMap(SortedMap sm)

     public static SortedSet synchronizedSortedSet(SortedSet ss)

     這些方法基本上返回具有同步集合方法版本的新類。比如,為了建立多安全執行緒且由ArrayList支援的List,可以使用如下代碼:

List list = Collection.synchronizedList(new ArrayList());

     注意,ArrayList執行個體馬上封裝起來,不存在對未同步化ArrayList的直接引用(即直接封裝匿名執行個體)。這是一種最安全的途徑。如果另一個線程要直接引用ArrayList執行個體,它可以執行非同步修改。


     下面給出一段多線程中安全遍曆集合元素的樣本。我們使用Iterator逐個掃描List中的元素,在多線程環境中,當遍曆當前集合中的元素時,一般希望阻止其他線程添加或刪除元素。安全遍曆的實現方法如下:

 

[java] view plain copy
  1. import java.util.*;  
  2.   
  3. public class SafeCollectionIteration extends Object {  
  4.     public static void main(String[] args) {  
  5.         //為了安全起見,僅使用同步列表的一個引用,這樣可以確保控制了所有訪問  
  6.         //集合必須同步化,這裡是一個List  
  7.         List wordList = Collections.synchronizedList(new ArrayList());  
  8.   
  9.         //wordList中的add方法是同步方法,會擷取wordList執行個體的對象鎖  
  10.         wordList.add("Iterators");  
  11.         wordList.add("require");  
  12.         wordList.add("special");  
  13.         wordList.add("handling");  
  14.   
  15.         //擷取wordList執行個體的對象鎖,  
  16.         //迭代時,阻塞其他線程調用add或remove等方法修改元素  
  17.         synchronized ( wordList ) {  
  18.             Iterator iter = wordList.iterator();  
  19.             while ( iter.hasNext() ) {  
  20.                 String s = (String) iter.next();  
  21.                 System.out.println("found string: " + s + ", length=" + s.length());  
  22.             }  
  23.         }  
  24.     }  
  25. }  

 

     這裡需要注意的是:在Java語言中,大部分的安全執行緒類都是相對安全執行緒的,它能保證對這個對象單獨的操作時安全執行緒的,我們在調用的時候不需要額外的保障措施,但是對於一些特定的連續調用,就可能需要在調用端使用額外的同步手段來保證調用的正確性。例如Vector、HashTable、Collections的synchronizedXxxx()方法封裝的集合等。

轉:【Java並發編程】之八:多線程環境中安全使用集合API(含代碼)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.