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