Java並發編程--線程封閉(Ad-hoc封閉 棧封閉 ThreadLocal)


線程封閉
實現好的並發是一件困難的事情,所以很多時候我們都想躲避並發。避免並發最簡單的方法就是線程封閉。什么是線程封閉呢?
就是把對象封裝到一個線程里,只有這一個線程能看到此對象。那么這個對象就算不是線程安全的也不會出現任何安全問題。實現線程封閉有哪些方法呢?

1:ad-hoc線程封閉

這是完全靠實現者控制的線程封閉,他的線程封閉完全靠實現者實現。Ad-hoc線程封閉非常脆弱,沒有任何一種語言特性能將對象封閉到目標線程上。

2:棧封閉

棧封閉是我們編程當中遇到的最多的線程封閉。什么是棧封閉呢?簡單的說就是局部變量。多個線程訪問一個方法,此方法中的局部變量都會被拷貝一分兒到線程棧中。所以局部變量是不被多個線程所共享的,也就不會出現並發問題。所以能用局部變量就別用全局的變量,全局變量容易引起並發問題。

public class Snippet {
    public int loadTheArk(Collection<Animal> candidates) {
        SortedSet<Animal> animals;
        int numPairs = 0;
        Animal candidate = null;
    
        // animals被封閉在方法中,不要使它們逸出!
        animals = new TreeSet<Animal>(new SpeciesGenderComparator());
        animals.addAll(candidates);
        for (Animal a : animals) {
            if (candidate == null || !candidate.isPotentialMate(a))
                candidate = a;
            else {
                ark.load(new AnimalPair(candidate, a));
                ++numPairs;
                candidate = null;
            }
        }
        return numPairs;
    }
}

 

3:ThreadLocal封閉

使用ThreadLocal是實現線程封閉的最好方法。ThreadLocal內部維護了一個Map,Map的key是每個線程的名稱,而Map的值就是我們要封閉的對象。每個線程中的對象都對應着Map中一個值,也就是ThreadLocal利用Map實現了對象的線程封閉。

詳細見另一篇博文:http://www.cnblogs.com/gnivor/p/4904793.html

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM