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