用純軟件來代替Mutex互斥鎖的方法可以用在多線程中嗎?
一、前言
在上一篇文章中,介紹了一種純軟件算法,用來實現(xiàn)臨界區(qū)的保護功能。
首先明確一下:如果利用操作系統(tǒng)提供的互斥鎖可以實現(xiàn)我需要的功能,我肯定使用互斥鎖,之所以介紹 Peterson 這個算法,主要是因為它比較有意思,很小巧,可以為我們帶來一些“規(guī)范的”編程之外的一些想法。
后臺也有一些小伙伴對這個算法發(fā)表了一些留言,只要有想法都非常好,就怕不去想。
其中有位朋友提到,這個算法只能用在 2 個線程中,是否有其他的類似算法,可以用在多線程中?
晚上下班后,我就花了點時間找到下面的這個算法,分享一下!
二、Micha Hofri 算法
這個算法我沒有找到名字,暫且以作者的名字來稱呼這個算法吧!
算法截圖:
從算法的主體代碼看,Hofri 算法主要是擴展了 Peterson 算法,都是使用 2 個全局變量數(shù)組來控制哪個線程可以進入臨界區(qū)。
這個算法的論證比較復(fù)雜,都是一些數(shù)學方面的證明,文章在這里:Proof of a Mutual Exclusion Algorithm-- A `Class'ic Example, 1989 年發(fā)表,感興趣的小伙伴可以自行去燒腦研究。
三、測試代碼
// 線程操作的資源
static int num = 0;
// 創(chuàng)建 10 個線程
#define THREAD_NUM 10
// 這 2 個全局變量控制算法
int flag[THREAD_NUM] = {0 };
int turn[THREAD_NUM - 1] = {0};
// 這是線程函數(shù)
void *thread_routine(void *arg)
{
int index = *(int *)arg;
for (int i = 0; i < 10000; ++i) // 線程循環(huán)次數(shù)
{
for (int j = 1; j < THREAD_NUM - 1; j++)
{
flag[index] = j;
turn[j] = index;
L:
for (int k = 1; k < THREAD_NUM; ++k)
{
if (k == index) continue;
if ((flag[k] >= j) && turn[j] == index)
goto L;
}
}
flag[index] = THREAD_NUM;
// 關(guān)鍵代碼段
num++;
flag[index] = 0;
}
return NULL;
}
void test()
{
// 用來傳遞線程的索引
int index[THREAD_NUM] = {0};
創(chuàng)建多個線程,執(zhí)行同一個函數(shù)
pthread_t t[THREAD_NUM];
for (int i = 0; i < THREAD_NUM; ++i)
{
index[i] = i;
pthread_create(&t[i], NULL, thread_routine, &index[i]);
}
}
編譯、執(zhí)行,所有線程執(zhí)行結(jié)束后,共享資源 num 變量可以得到正確的結(jié)果。
四、總結(jié)
還是重復(fù)一下文章開頭說的話,這里的算法僅僅是說明它可以完成保護臨界區(qū)的功能,但是在實際項目中,真心不建議這么來用,畢竟代碼的可維護性是非常重要的!
請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
11月20日火熱報名中>> 2024 智能家居出海論壇
-
11月28日立即報名>>> 2024工程師系列—工業(yè)電子技術(shù)在線會議
-
12月19日立即報名>> 【線下會議】OFweek 2024(第九屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會
-
即日-12.26火熱報名中>> OFweek2024中國智造CIO在線峰會
-
即日-2025.8.1立即下載>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍皮書》
-
精彩回顧立即查看>> 【在線會議】多物理場仿真助跑新能源汽車
推薦專題
- 1 腦機接口芯片,華為出了新專利!
- 2 今年諾獎對人工智能的重視,給我們的基礎(chǔ)教育提了個醒
- 3 銀行業(yè)AI大模型,從入局到求變
- 4 巨頭搶布局,VC狂撒錢,為了能讓「AI讀心」這些公司卷瘋了
- 5 阿斯麥ASML:“骨折級”洋相,又成AI第一殺手?
- 6 蘋果市值創(chuàng)新高,iPhone 16能否助力突破4萬億美元大關(guān)?
- 7 一場“載入史冊”的發(fā)布會,讓馬斯克失去了4700億
- 8 百度谷歌比較研究2024:中美“遠古AI龍頭”的現(xiàn)狀與趨勢
- 9 洞見AI風潮 第二屆vivo藍河操作系統(tǒng)創(chuàng)新賽開啟招募
- 10 地平線開啟配售,阿里百度各砸5000萬美金,市值最高超500億
- 高級軟件工程師 廣東省/深圳市
- 自動化高級工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市