ThreadLocal的核心思想很簡單:為每個獨(dú)立的線程提供一個變量的副本。
Java提供的synchronized關(guān)鍵字使用了“同步鎖”的機(jī)制來阻止線程的競爭訪問,即“以時間換空間”。: " 10pt; FONT-SIZE:> ThreadLocal則使用了“拷貝副本”的方式,人人有份,你用你的,我用我的,大家互不影響,是“以空間換時間”。每個線程修改變量時,實(shí)際上修改的是變量的副本,不怕影響到其它線程。
為了加深對ThreadLocal的理解,下面我使用一個例子來演示ThreadLocal如何隔離線程間的變量訪問和修改:
【1】SerialNum類
package example.thread.threadLocal;
public class SerialNum {
private static int nextSerialNum = 1;
@SuppressWarnings("unchecked")
private static ThreadLocal serialNum = new ThreadLocal() {
protected synchronized Object initialValue() {
return new Integer(nextSerialNum++);
}
};
public static int get() {
return ((Integer) (serialNum.get())).intValue();
}
@SuppressWarnings("unchecked")
public static void set(Integer newSerial){
serialNum.set(newSerial);
}
}
Java提供的synchronized關(guān)鍵字使用了“同步鎖”的機(jī)制來阻止線程的競爭訪問,即“以時間換空間”。: " 10pt; FONT-SIZE:> ThreadLocal則使用了“拷貝副本”的方式,人人有份,你用你的,我用我的,大家互不影響,是“以空間換時間”。每個線程修改變量時,實(shí)際上修改的是變量的副本,不怕影響到其它線程。
為了加深對ThreadLocal的理解,下面我使用一個例子來演示ThreadLocal如何隔離線程間的變量訪問和修改:
【1】SerialNum類
package example.thread.threadLocal;
public class SerialNum {
private static int nextSerialNum = 1;
@SuppressWarnings("unchecked")
private static ThreadLocal serialNum = new ThreadLocal() {
protected synchronized Object initialValue() {
return new Integer(nextSerialNum++);
}
};
public static int get() {
return ((Integer) (serialNum.get())).intValue();
}
@SuppressWarnings("unchecked")
public static void set(Integer newSerial){
serialNum.set(newSerial);
}
}