7 1 同步的概念與執行緒同步

2021-10-02 12:19:45 字數 753 閱讀 7715

1、同步概念

所謂同步,即同時起步,協調一致。不同的物件,對「同步」的理解方式略有不同。例如:

1、裝置同步,是指在兩個裝置之間規定乙個共同的時間參考;

2、資料庫同步,是指讓兩個或多個資料庫內容保持一致,或者按需要部分保持一致;

3、檔案同步,是指讓兩個或多個資料夾裡的檔案保持一致。

4、程式設計中、通訊中所說的同步與生活中大家印象中的同步概念略有差異。主旨在協同步調,按預定的先後次序執行。

2、執行緒同步

1、執行緒同步,指乙個執行緒發出某一功能呼叫時,在沒有得到結果之前,該呼叫不返回。同時其它執行緒為保證資料一致性,不能呼叫該功能。

2、「同步」的目的,是為了避免資料混亂,解決與時間有關的錯誤。實際上,不僅執行緒間需要同步,程序間、訊號間等等都需要同步機制。

因此,所有「多個控制流,共同操作乙個共享資源」的情況,都需要同步。

3、資料混亂原因

1. 資源共享(獨享資源則不會)	

2. 排程隨機(意味著資料訪問會出現競爭)

3. 執行緒間缺乏必要的同步機制。

以上3點中,前兩點不能改變,欲提高效率,傳遞資料,資源必須共享。只要共享資源,就一定會出現競爭。只要存在競爭關係,資料就很容易出現混亂。

所以只能從第三點著手解決。使多個執行緒在訪問共享資源的時候,出現互斥。

執行緒同步概念

同步即協同步調,按預定的先後次序執行。1.資源共享 獨享資源則不會 2.排程隨機 意味著資料訪問會出現競爭 3.執行緒間缺乏必要的同步機制。以上3點中,前兩點不能改變,欲提高效率,傳遞資料,資源必須共享。只要共享資源,就一定會出現競爭。只要存在競爭關係,資料就很容易出現混亂。所以只能從第三點著手解決...

多執行緒同步概念

不管是多執行緒還是多程序,涉及到共享相同的記憶體時,需要確保好同步問題。對執行緒來說,需要確保每個執行緒看到一致的資料檢視。如果每個執行緒使用的變數都是其他執行緒不會讀取和修改的,那麼就不存在一致性問題,同樣的,如果變數是唯讀的,多個執行緒同時讀取該變數也不會有一致性問題。但是如果其中的某個執行緒去...

執行緒與同步

系統中的執行緒與程序 程序包含window控制代碼,檔案系統和其他核心物件等,每個程序系統都會分配乙個虛擬記憶體,每個程序最少有乙個執行緒。執行緒是執行程式必須的獨立的指令流,執行緒也有自己的堆疊 記憶體 應用程式的記憶體和堆由乙個程序中的所有執行緒共享,所引線程之間的交換非常快,但是由於他們共享所...