一、前言 二、Micha Hofri 算法 三、測試代碼 四、總結(jié) 一、前言 在上一篇文章中,介紹了一種
純軟件 算法,用來實現(xiàn)
臨界區(qū)的保護 功能,文章鏈接:
C語言 邊角料2:用純
軟件 來代替Mutex互斥鎖。首先明確一下:如果利用操作系統(tǒng)提供的
互斥鎖 可以實現(xiàn)我需要的功能,我
肯定 使用互斥鎖,之所以介紹 Peterson 這個算法,主要是因為它比較
有意思,很小巧 ,可以為我們帶來一些
“規(guī)范的” 編程之外的一些想法。后臺也有一些小伙伴對這個算法發(fā)表了一些留言,只要有想法都非常好,就怕不去想。其中有位朋友提到,這個算法只能用在
2 個 線程中,是否有其他的類似算法,可以用在
多線程 中?晚上下班后,我就花了點時間找到下面的這個算法,分享一下!
二、Micha Hofri 算法 這個算法我沒有找到名字,暫且以作者的名字來稱呼這個算法吧!算法截圖:
從算法的主體代碼看,Hofri 算法主要是
擴展 了 Peterson 算法,都是使用
2 個全局變量數(shù)組 來控制哪個線程可以進入臨界區(qū)。這個算法的論證
比較復雜 ,都是一些數(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)