c語言多線程并發(fā)例子 c語言有沒有多線程這個概念?
c語言有沒有多線程這個概念?線程:線程是程序中的執(zhí)行流。每個線程都有自己的特殊寄存器(堆棧指針、程序計數(shù)器等),但代碼區(qū)域是共享的,即不同的線程可以執(zhí)行相同的函數(shù)。多線程:多線程是指一個程序包含多個執(zhí)
c語言有沒有多線程這個概念?
線程:線程是程序中的執(zhí)行流。每個線程都有自己的特殊寄存器(堆棧指針、程序計數(shù)器等),但代碼區(qū)域是共享的,即不同的線程可以執(zhí)行相同的函數(shù)。
多線程:多線程是指一個程序包含多個執(zhí)行流,即一個程序可以運行多個不同的線程來同時執(zhí)行不同的任務,也就是說,一個程序可以創(chuàng)建多個并行執(zhí)行線程來完成自己的任務。
C語言設計之初,沒有設計多線程機制,因為隨著軟硬件的發(fā)展和需求的發(fā)展。后來,C語言開發(fā)了線程庫來支持多線程操作和應用。
本文主要介紹了基于Linux的C多線程技術。在編譯C多線程時,一方面必須指定Linux C語言的多線程庫pthread才能正確編譯(例如:GCC test)。C-O test-lpthread);另一方面,應該包含線程頭文件#include。下面簡要解釋一下原因:
鎖定是因為操作不是原子的。讓我們以I操作為例。參見下面兩個圖。
我這個操作需要
看上面的第二個圖,你能很清楚地理解這個過程嗎?
鎖定是為了確保上述三個步驟是原子操作。
回到問題上來,只有一個線程要寫,沒有競爭,所以不需要鎖定。
但是,如果你看第一張圖片,因為主內存和本地內存的存在
在一個線程寫入后,其他線程無法立即看到它。這就是可見性問題。
添加volatile關鍵字后,它將在操作后強制工作內存和主內存同步,以確保其他線程可以立即看到它。
多個線程可以讀一個變量,只有一個線程可以對這個變量進行寫,到底要不要加鎖?
1:互斥和同步:公共資源只能由一個進程或線程同時使用。多個進程或線程不能同時使用公共資源。R同步:兩個或多個進程或線程在運行進程中協(xié)調,并按預定順序運行。R解決方案:mutex、條件變量、讀寫鎖、自旋鎖、信號量(mutex和synchronization)r2:mutex(synchronization)R mutex是一種簡單的鎖定方法,用于控制對共享資源的訪問。互斥只有兩種狀態(tài),即鎖定和解鎖。R的特點:唯一性、原子性、非忙等待3:條件變量(同步)條件變量用于等待,不用于鎖定。條件變量用于在特殊情況發(fā)生之前自動阻止線程。多線程不使用condition變量而等待一個條件的發(fā)生是很合適的,這樣每個線程就會不斷地嘗試互斥并檢測是否發(fā)生了該條件,從而浪費了系統(tǒng)資源。R4:讀寫鎖定(同步)三種狀態(tài):讀模式下的鎖定狀態(tài)、寫模式下的鎖定狀態(tài)和無鎖定狀態(tài)。讀寫鎖的特點:如果其他線程讀取數(shù)據(jù),則允許讀取,但不允許寫入;如果其他線程寫入數(shù)據(jù),則不允許讀取或寫入。R[讀寫鎖規(guī)則]: