日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > 滿天芯
[導讀]一、前言二、MichaHofri算法三、測試代碼四、總結(jié)一、前言在上一篇文章中,介紹了一種純軟件算法,用來實現(xiàn)臨界區(qū)的保護功能,文章鏈接:C語言邊角料2:用純軟件來代替Mutex互斥鎖。首先明確一下:如果利用操作系統(tǒng)提供的互斥鎖可以實現(xiàn)我需要的功能,我肯定使用互斥鎖,之所以介紹P...


  • 一、前言

  • 二、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)
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉