當(dāng)一個(gè)線程對(duì)共享的數(shù)據(jù)進(jìn)行操作時(shí),應(yīng)使之成為一個(gè)”原子操作“,即在沒(méi)有完成相關(guān)操作之前,不允許其他線程打斷它,否則,就會(huì)破壞數(shù)據(jù)的完整性,必然會(huì)得到錯(cuò)誤的處理結(jié)果,這就是線程的同步。
在多線程應(yīng)用中,考慮不同線程之間的數(shù)據(jù)同步和防止死鎖。當(dāng)兩個(gè)或多個(gè)線程之間同時(shí)等待對(duì)方釋放資源的時(shí)候就會(huì)形成線程之間的死鎖。為了防止死鎖的發(fā)生,需要通過(guò)同步來(lái)實(shí)現(xiàn)線程安全。
線程互斥是指對(duì)于共享的進(jìn)程系統(tǒng)資源,在各單個(gè)線程訪問(wèn)時(shí)的排它性。當(dāng)有若干個(gè)線程都要使用某一共享資源時(shí),任何時(shí)刻最多只允許一個(gè)線程去使用,其它要使用該資源的線程必須等待,直到占用資源者釋放該資源。線程互斥可以看成是一種特殊的線程同步。
線程間的同步方法大體可分為兩類:用戶模式和內(nèi)核模式。顧名思義,內(nèi)核模式就是指利用系統(tǒng)內(nèi)核對(duì)象的單一性來(lái)進(jìn)行同步,使用時(shí)需要切換內(nèi)核態(tài)與用戶態(tài),而用戶模式就是不需要切換到內(nèi)核態(tài),只在用戶態(tài)完成操作。
用戶模式下的方法有:原子操作(例如一個(gè)單一的全局變量),臨界區(qū)。內(nèi)核模式下的方法有:事件,信號(hào)量,互斥量。
實(shí)現(xiàn)線程同步的方法
1. 同步代碼方法:sychronized 關(guān)鍵字修飾的方法
2. 同步代碼塊:sychronized 關(guān)鍵字修飾的代碼塊
3. 使用特殊變量域volatile實(shí)現(xiàn)線程同步:volatile關(guān)鍵字為域變量的訪問(wèn)提供了一種免鎖機(jī)制
4. 使用重入鎖實(shí)現(xiàn)線程同步:reentrantlock類是可沖入、互斥、實(shí)現(xiàn)了lock接口的鎖他與sychronized方法具有相同的基本行為和語(yǔ)義