四種方式 sychronized關鍵字
sychronized method(){}
sychronized (objectReference) {/*block*/}
static synchronized method(){}
sychronized(classname.class)
其中1和2是代表鎖當前對象,即一個對象就一個鎖,3和4代表鎖這個類,即這個類的鎖
要注意的是sychronized method()不是鎖這個函數,而是鎖對象,即:如果這個類中有兩個方法都是sychronized,那麼只要有兩個線程共享一個該類的reference,每個調用這兩個方法之一,不管是否同一個方法,都會用這個對象鎖進行同步。鎖類的3和4類推,即該類的不同reference調用了sychronized區段的咚咚就會受類鎖的控制
還有,如果兩個函數調用的先後順序不能被打斷,那麼可以有個專門的鎖對象來完成這個任務:
class MyLock
{
synchronized getLock()
{
//####還沒寫完
}
}
五個等級 參見effective java Item 52 : Document thread safety
immutable 不可變對象
thread-safe 線程安全的,可以放心使用,如java.util.Timer
conditionally thread-safe 條件線程安全的,如Vector和Hashtable,一般是安全的,除非存在幾個方法調用之間的順序不能被打斷,這時可以用額外的鎖來完成
thread-compatible 可以使用synchronized (objectReference)來協助完成對線程的調用
thread-hostile 不安全的
wait & notifyAll
在循環中使用wait 使用notifyAll而不是notify
pipe
java中也有pipe的,四個類:PipedInputStream, PipedInputReader, PipedOutputStream, PipedOutputWriter 下面是一段生產者消費者的代碼(摘自core javaII):
/* set up pipes */
PipedOutputStream pout1 = new PipedOutputStream();
PipedInputStream pin1 = new PipedInputStream(pout1);
PipedOutputStream pout2 = new PipedOutputStream();
PipedInputStream pin2 = new PipedInputStream(pout2);
/* construct threads */
Producer prod = new Producer(pout1);
Filter filt = new Filter(pin1, pout2);
Consumer cons = new Consumer(pin2);
/* start threads */
prod.start();
filt.start();
cons.start();