0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

互斥鎖、條件變量、讀寫鎖、自旋鎖及信號(hào)量介紹

科技綠洲 ? 來源:Linux開發(fā)架構(gòu)之路 ? 作者:Linux開發(fā)架構(gòu)之路 ? 2023-11-10 16:16 ? 次閱讀

一、互斥鎖(同步)

在多任務(wù)操作系統(tǒng)中,同時(shí)運(yùn)行的多個(gè)任務(wù)可能都需要使用同一種資源。這個(gè)過程有點(diǎn)類似于,公司部門里,我在使用著打印機(jī)打印東西的同時(shí)(還沒有打印完),別人剛好也在此刻使用打印機(jī)打印東西,如果不做任何處理的話,打印出來的東西肯定是錯(cuò)亂的。

在線程里也有這么一把鎖——互斥鎖(mutex),互斥鎖是一種簡(jiǎn)單的加鎖的方法來控制對(duì)共享資源的訪問,互斥鎖只有兩種狀態(tài),即上鎖( lock )和解鎖( unlock )。

【互斥鎖的特點(diǎn)】:

  1. 原子性:把一個(gè)互斥量鎖定為一個(gè)原子操作,這意味著操作系統(tǒng)(或pthread函數(shù)庫)保證了如果一個(gè)線程鎖定了一個(gè)互斥量,沒有其他線程在同一時(shí)間可以成功鎖定這個(gè)互斥量;
  2. 唯一性:如果一個(gè)線程鎖定了一個(gè)互斥量,在它解除鎖定之前,沒有其他線程可以鎖定這個(gè)互斥量;
  3. 非繁忙等待:如果一個(gè)線程已經(jīng)鎖定了一個(gè)互斥量,第二個(gè)線程又試圖去鎖定這個(gè)互斥量,則第二個(gè)線程將被掛起(不占用任何cpu資源),直到第一個(gè)線程解除對(duì)這個(gè)互斥量的鎖定為止,第二個(gè)線程則被喚醒并繼續(xù)執(zhí)行,同時(shí)鎖定這個(gè)互斥量。

【互斥鎖的操作流程如下】:

  1. 在訪問共享資源后臨界區(qū)域前,對(duì)互斥鎖進(jìn)行加鎖;
  2. 在訪問完成后釋放互斥鎖導(dǎo)上的鎖。在訪問完成后釋放互斥鎖導(dǎo)上的鎖;
  3. 對(duì)互斥鎖進(jìn)行加鎖后,任何其他試圖再次對(duì)互斥鎖加鎖的線程將會(huì)被阻塞,直到鎖被釋放。對(duì)互斥鎖進(jìn)行加鎖后,任何其他試圖再次對(duì)互斥鎖加鎖的線程將會(huì)被阻塞,直到鎖被釋放。
#include < pthread.h >
#include < time.h >
// 初始化一個(gè)互斥鎖。
int pthread_mutex_init(pthread_mutex_t *mutex, 
						const pthread_mutexattr_t *attr);
// 對(duì)互斥鎖上鎖,若互斥鎖已經(jīng)上鎖,則調(diào)用者一直阻塞,
// 直到互斥鎖解鎖后再上鎖。
int pthread_mutex_lock(pthread_mutex_t *mutex);
// 調(diào)用該函數(shù)時(shí),若互斥鎖未加鎖,則上鎖,返回 0;
// 若互斥鎖已加鎖,則函數(shù)直接返回失敗,即 EBUSY。
int pthread_mutex_trylock(pthread_mutex_t *mutex);
// 當(dāng)線程試圖獲取一個(gè)已加鎖的互斥量時(shí),pthread_mutex_timedlock 互斥量
// 原語允許綁定線程阻塞時(shí)間。即非阻塞加鎖互斥量。
int pthread_mutex_timedlock(pthread_mutex_t *restrict mutex,
const struct timespec *restrict abs_timeout);
// 對(duì)指定的互斥鎖解鎖。
int pthread_mutex_unlock(pthread_mutex_t *mutex);
// 銷毀指定的一個(gè)互斥鎖?;コ怄i在使用完畢后,
// 必須要對(duì)互斥鎖進(jìn)行銷毀,以釋放資源。
int pthread_mutex_destroy(pthread_mutex_t *mutex);

【Demo】(阻塞模式):

//使用互斥量解決多線程搶占資源的問題
#include < stdio.h >
#include < stdlib.h >
#include < unistd.h >
#include < pthread.h >
#include < string.h >

char* buf[5]; //字符指針數(shù)組  全局變量
int pos; //用于指定上面數(shù)組的下標(biāo)

//1.定義互斥量
pthread_mutex_t mutex;

void *task(void *p)
{
    //3.使用互斥量進(jìn)行加鎖
    pthread_mutex_lock(&mutex);

    buf[pos] = (char *)p;
    sleep(1);
    pos++;

    //4.使用互斥量進(jìn)行解鎖
    pthread_mutex_unlock(&mutex);
}

int main(void)
{
    //2.初始化互斥量, 默認(rèn)屬性
    pthread_mutex_init(&mutex, NULL);

    //1.啟動(dòng)一個(gè)線程 向數(shù)組中存儲(chǔ)內(nèi)容
    pthread_t tid, tid2;
    pthread_create(&tid, NULL, task, (void *)"zhangfei");
    pthread_create(&tid2, NULL, task, (void *)"guanyu");
    //2.主線程進(jìn)程等待,并且打印最終的結(jié)果
    pthread_join(tid, NULL);
    pthread_join(tid2, NULL);

    //5.銷毀互斥量
    pthread_mutex_destroy(&mutex);

    int i = 0;
    printf("字符指針數(shù)組中的內(nèi)容是:");
    for(i = 0; i < pos; ++i)
    {
        printf("%s ", buf[i]);
    }
    printf("n");
    return 0;
}

【Demo】(非阻塞模式):

#include < stdio.h >
#include < pthread.h >
#include < time.h >
#include < string.h >

int main (void)
{
    int err;
    struct timespec tout;
    struct tm *tmp;
    char buf[64];
    pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;

    pthread_mutex_lock (&lock);
    printf ("mutex is lockedn");
    clock_gettime (CLOCK_REALTIME, &tout);
    tmp = localtime (&tout.tv_sec); 
    strftime (buf, sizeof (buf), "%r", tmp);
    printf ("current time is %sn", buf);
    tout.tv_sec += 10;
    err = pthread_mutex_timedlock (&lock, &tout);
    clock_gettime (CLOCK_REALTIME, &tout);
    tmp = localtime (&tout.tv_sec);
    strftime (buf, sizeof (buf), "%r", tmp);
    printf ("the time is now %sn", buf);
    if (err == 0)
        printf ("mutex locked againn");
    else 
        printf ("can`t lock mutex again:%sn", strerror (err));
    return 0;
}

二、條件變量(同步)

與互斥鎖不同,條件變量是用來等待而不是用來上鎖的。條件變量用來自動(dòng)阻塞一個(gè)線程,直 到某特殊情況發(fā)生為止。通常條件變量和互斥鎖同時(shí)使用。

條件變量使我們可以睡眠等待某種條件出現(xiàn)。條件變量是利用線程間共享的全局變量進(jìn)行同步 的一種機(jī)制,主要包括兩個(gè)動(dòng)作:

一個(gè)線程等待"條件變量的條件成立"而掛起;

另一個(gè)線程使 “條件成立”(給出條件成立信號(hào))。

【原理】:

條件的檢測(cè)是在互斥鎖的保護(hù)下進(jìn)行的。線程在改變條件狀態(tài)之前必須首先鎖住互斥量。如果一個(gè)條件為假,一個(gè)線程自動(dòng)阻塞,并釋放等待狀態(tài)改變的互斥鎖。如果另一個(gè)線程改變了條件,它發(fā)信號(hào)給關(guān)聯(lián)的條件變量,喚醒一個(gè)或多個(gè)等待它的線程,重新獲得互斥鎖,重新評(píng)價(jià)條件。如果兩進(jìn)程共享可讀寫的內(nèi)存,條件變量 可以被用來實(shí)現(xiàn)這兩進(jìn)程間的線程同步。

【條件變量的操作流程如下】:

  1. 初始化:init()或者pthread_cond_tcond=PTHREAD_COND_INITIALIER;屬性置為NULL;
  2. 等待條件成立:pthread_wait,pthread_timewait.wait()釋放鎖,并阻塞等待條件變量為真 timewait()設(shè)置等待時(shí)間,仍未signal,返回ETIMEOUT(加鎖保證只有一個(gè)線程wait);
  3. 激活條件變量:pthread_cond_signal,pthread_cond_broadcast(激活所有等待線程)
  4. 清除條件變量:destroy;無線程等待,否則返回EBUSY清除條件變量:destroy;無線程等待,否則返回EBUSY
#include < pthread.h >
// 初始化條件變量
int pthread_cond_init(pthread_cond_t *cond,
						pthread_condattr_t *cond_attr);
// 阻塞等待
int pthread_cond_wait(pthread_cond_t *cond,pthread_mutex_t *mutex);
// 超時(shí)等待
int pthread_cond_timewait(pthread_cond_t *cond,pthread_mutex *mutex,
						const timespec *abstime);
// 解除所有線程的阻塞
int pthread_cond_destroy(pthread_cond_t *cond);
// 至少喚醒一個(gè)等待該條件的線程
int pthread_cond_signal(pthread_cond_t *cond);
// 喚醒等待該條件的所有線程
int pthread_cond_broadcast(pthread_cond_t *cond);

1、線程的條件變量實(shí)例1

Jack開著一輛出租車來到一個(gè)站點(diǎn)停車,看見沒人就走了。過段時(shí)間,Susan來到站點(diǎn)準(zhǔn)備乘車,但是沒有來,于是就等著。過了一會(huì)Mike開著車來到了這個(gè)站點(diǎn),Sunsan就上了Mike的車走了。如圖所示:

圖片

#include < stdio.h >  
#include < stdlib.h >  
#include < unistd.h >  
#include < pthread.h >  

pthread_cond_t taxicond = PTHREAD_COND_INITIALIZER;  
pthread_mutex_t taximutex = PTHREAD_MUTEX_INITIALIZER;  

void *traveler_arrive(void *name)  
{  
    char *p = (char *)name;  

    printf ("Travelr: %s need a taxi now!n", p);  
    // 加鎖,把信號(hào)量加入隊(duì)列,釋放信號(hào)量
    pthread_mutex_lock(&taximutex);  
    pthread_cond_wait(&taxicond, &taximutex);  
    pthread_mutex_unlock(&taximutex);  
    printf ("traveler: %s now got a taxi!n", p);  
    pthread_exit(NULL);  
}  

void *taxi_arrive(void *name)  
{  
    char *p = (char *)name;  
    printf ("Taxi: %s arrives.n", p);
    // 給線程或者條件發(fā)信號(hào),一定要在改變條件狀態(tài)后再給線程發(fā)信號(hào)
    pthread_cond_signal(&taxicond);  
    pthread_exit(NULL);  
}  

int main (int argc, char **argv)  
{  
    char *name;  
    pthread_t thread;  
    pthread_attr_t threadattr; // 線程屬性 
    pthread_attr_init(&threadattr);  // 線程屬性初始化

    // 創(chuàng)建三個(gè)線程
    name = "Jack";  
    pthread_create(&thread, &threadattr, taxi_arrive, (void *)name);  
    sleep(1);  
    name = "Susan";  
    pthread_create(&thread, &threadattr, traveler_arrive, (void *)name);  
    sleep(1);  
    name = "Mike";  
    pthread_create(&thread, &threadattr, taxi_arrive, (void *)name);  
    sleep(1);  

    return 0;  
}

2、線程的條件變量實(shí)例2

Jack開著一輛出租車來到一個(gè)站點(diǎn)停車,看見沒人就等著。過段時(shí)間,Susan來到站點(diǎn)準(zhǔn)備乘車看見了Jack的出租車,于是就上去了。過了一會(huì)Mike開著車來到了這個(gè)站點(diǎn),看見沒人救等著。如圖所示:

圖片

#include < stdio.h >
#include < stdlib.h >
#include < unistd.h >
#include < pthread.h >

int travelercount = 0;
pthread_cond_t taxicond = PTHREAD_COND_INITIALIZER;
pthread_mutex_t taximutex = PTHREAD_MUTEX_INITIALIZER;

void *traveler_arrive(void *name)
{
    char *p = (char *)name;

    pthread_mutex_lock(&taximutex);

    printf ("traveler: %s need a taxi now!n", p);
    travelercount++;
    pthread_cond_wait(&taxicond, &taximutex);

    pthread_mutex_unlock(&taximutex);
    printf ("traveler: %s now got a taxi!n", p);
    pthread_exit(NULL);
}

void *taxi_arrive(void *name)
{
    char *p = (char *)name;
    printf ("Taxi: %s arrives.n", p);
    for(;;)
    {
        if(travelercount)
        {
            pthread_cond_signal(&taxicond);
            travelercount--;
            break;
        }
    }
    pthread_exit(NULL);
}

int main (int argc, char **argv)
{
    char *name;
    pthread_t thread;
    pthread_attr_t threadattr;
    pthread_attr_init(&threadattr);

    name = "Jack";
    pthread_create(&thread, &threadattr, taxi_arrive, name);
    sleep(1);
    name = "Susan";
    pthread_create(&thread, &threadattr, traveler_arrive, name);
    sleep(3);
    name = "Mike";
    pthread_create(&thread, &threadattr, taxi_arrive, name);
    sleep(4);

    return 0;
}

3、虛假喚醒(spurious wakeup)

虛假喚醒(spurious wakeup)在采用條件等待時(shí):

while(條件不滿足)
{  
   condition_wait(cond, mutex);  
}  
// 而不是:  
If( 條件不滿足 )
{  
   Condition_wait(cond,mutex);  
}

這是因?yàn)榭赡軙?huì)存在虛假喚醒”spurious wakeup”的情況。

也就是說,即使沒有線程調(diào)用condition_signal, 原先調(diào)用condition_wait的函數(shù)也可能會(huì)返回。此時(shí)線程被喚醒了,但是條件并不滿足,這個(gè)時(shí)候如果不對(duì)條件進(jìn)行檢查而往下執(zhí)行,就可能會(huì)導(dǎo)致后續(xù)的處理出現(xiàn)錯(cuò)誤。

虛假喚醒在linux的多處理器系統(tǒng)中/在程序接收到信號(hào)時(shí)可能回發(fā)生。在Windows系統(tǒng)和JAVA虛擬機(jī)上也存在。在系統(tǒng)設(shè)計(jì)時(shí)應(yīng)該可以避免虛假喚醒,但是這會(huì)影響條件變量的執(zhí)行效率,而既然通過while循環(huán)就能避免虛假喚醒造成的錯(cuò)誤,因此程序的邏輯就變成了while循環(huán)的情況。

四、讀寫鎖(同步)

讀寫鎖與互斥量類似,不過讀寫鎖允許更改的并行性,也叫共享互斥鎖?;コ饬恳词擎i住狀態(tài),要么就是不加鎖狀態(tài),而且一次只有一個(gè)線程可以對(duì)其加鎖。讀寫鎖可以有3種狀態(tài):讀模式下加鎖狀態(tài)、寫模式加鎖狀態(tài)、不加鎖狀態(tài)。

一次只有一個(gè)線程可以占有寫模式的讀寫鎖,但是多個(gè)線程可以同時(shí)占有讀模式的讀寫鎖(允許多個(gè)線程讀但只允許一個(gè)線程寫)。

【讀寫鎖的特點(diǎn)】:

如果有其它線程讀數(shù)據(jù),則允許其它線程執(zhí)行讀操作,但不允許寫操作;

如果有其它線程寫數(shù)據(jù),則其它線程都不允許讀、寫操作。

【讀寫鎖的規(guī)則】:

如果某線程申請(qǐng)了讀鎖,其它線程可以再申請(qǐng)讀鎖,但不能申請(qǐng)寫鎖;

如果某線程申請(qǐng)了寫鎖,其它線程不能申請(qǐng)讀鎖,也不能申請(qǐng)寫鎖。

讀寫鎖適合于對(duì)數(shù)據(jù)結(jié)構(gòu)的讀次數(shù)比寫次數(shù)多得多的情況。

#include < pthread.h >
// 初始化讀寫鎖
int pthread_rwlock_init(pthread_rwlock_t *rwlock, 
						const pthread_rwlockattr_t *attr); 
// 申請(qǐng)讀鎖
int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock ); 
// 申請(qǐng)寫鎖
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock ); 
// 嘗試以非阻塞的方式來在讀寫鎖上獲取寫鎖,
// 如果有任何的讀者或?qū)懻叱钟性撴i,則立即失敗返回。
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock); 
// 解鎖
int pthread_rwlock_unlock (pthread_rwlock_t *rwlock); 
// 銷毀讀寫鎖
int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);

【Demo】:

// 一個(gè)使用讀寫鎖來實(shí)現(xiàn) 4 個(gè)線程讀寫一段數(shù)據(jù)是實(shí)例。
// 在此示例程序中,共創(chuàng)建了 4 個(gè)線程,
// 其中兩個(gè)線程用來寫入數(shù)據(jù),兩個(gè)線程用來讀取數(shù)據(jù)
#include < stdio.h >  
#include < unistd.h >  
#include < pthread.h >  
pthread_rwlock_t rwlock; //讀寫鎖  
int num = 1;  

//讀操作,其他線程允許讀操作,卻不允許寫操作  
void *fun1(void *arg)  
{  
    while(1)  
    {  
        pthread_rwlock_rdlock(&rwlock);
        printf("read num first == %dn", num);
        pthread_rwlock_unlock(&rwlock);
        sleep(1);
    }
}

//讀操作,其他線程允許讀操作,卻不允許寫操作  
void *fun2(void *arg)
{
    while(1)
    {
        pthread_rwlock_rdlock(&rwlock);
        printf("read num second == %dn", num);
        pthread_rwlock_unlock(&rwlock);
        sleep(2);
    }
}

//寫操作,其它線程都不允許讀或?qū)懖僮? 
void *fun3(void *arg)
{
    while(1)
    {
        pthread_rwlock_wrlock(&rwlock);
        num++;
        printf("write thread firstn");
        pthread_rwlock_unlock(&rwlock);
        sleep(2);
    }
}

//寫操作,其它線程都不允許讀或?qū)懖僮? 
void *fun4(void *arg)
{
    while(1)
    {  
        pthread_rwlock_wrlock(&rwlock);  
        num++;  
        printf("write thread secondn");  
        pthread_rwlock_unlock(&rwlock);  
        sleep(1);  
    }  
}  

int main()  
{  
    pthread_t ptd1, ptd2, ptd3, ptd4;  

    pthread_rwlock_init(&rwlock, NULL);//初始化一個(gè)讀寫鎖  

    //創(chuàng)建線程  
    pthread_create(&ptd1, NULL, fun1, NULL);  
    pthread_create(&ptd2, NULL, fun2, NULL);  
    pthread_create(&ptd3, NULL, fun3, NULL);  
    pthread_create(&ptd4, NULL, fun4, NULL);  

    //等待線程結(jié)束,回收其資源  
    pthread_join(ptd1, NULL);  
    pthread_join(ptd2, NULL);  
    pthread_join(ptd3, NULL);  
    pthread_join(ptd4, NULL);  

    pthread_rwlock_destroy(&rwlock);//銷毀讀寫鎖  

    return 0;  
}

五、自旋鎖(同步)

自旋鎖與互斥量功能一樣,唯一一點(diǎn)不同的就是互斥量阻塞后休眠讓出cpu,而自旋鎖阻塞后不會(huì)讓出cpu,會(huì)一直忙等待,直到得到鎖。

自旋鎖在用戶態(tài)使用的比較少,在內(nèi)核使用的比較多!自旋鎖的使用場(chǎng)景:鎖的持有時(shí)間比較短,或者說小于2次上下文切換的時(shí)間。

自旋鎖在用戶態(tài)的函數(shù)接口和互斥量一樣,把pthread_mutex_xxx()中mutex換成spin,如:pthread_spin_init()。

六、信號(hào)量(同步與互斥)

信號(hào)量廣泛用于進(jìn)程或線程間的同步和互斥,信號(hào)量本質(zhì)上是一個(gè)非負(fù)的整數(shù)計(jì)數(shù)器,它被用來控制對(duì)公共資源的訪問。

編程時(shí)可根據(jù)操作信號(hào)量值的結(jié)果判斷是否對(duì)公共資源具有訪問的權(quán)限,當(dāng)信號(hào)量值大于 0 時(shí),則可以訪問,否則將阻塞。PV 原語是對(duì)信號(hào)量的操作,一次 P 操作使信號(hào)量減1,一次 V 操作使信號(hào)量加1。

#include < semaphore.h >
// 初始化信號(hào)量
int sem_init(sem_t *sem, int pshared, unsigned int value);
// 信號(hào)量 P 操作(減 1)
int sem_wait(sem_t *sem);
// 以非阻塞的方式來對(duì)信號(hào)量進(jìn)行減 1 操作
int sem_trywait(sem_t *sem);
// 信號(hào)量 V 操作(加 1)
int sem_post(sem_t *sem);
// 獲取信號(hào)量的值
int sem_getvalue(sem_t *sem, int *sval);
// 銷毀信號(hào)量
int sem_destroy(sem_t *sem);

【信號(hào)量用于同步】:

圖片

// 信號(hào)量用于同步實(shí)例
#include < stdio.h >
#include < unistd.h >
#include < pthread.h >
#include < semaphore.h >

sem_t sem_g,sem_p;   //定義兩個(gè)信號(hào)量
char ch = 'a';

void *pthread_g(void *arg)  //此線程改變字符ch的值
{
    while(1)
    {
        sem_wait(&sem_g);
        ch++;
        sleep(1);
        sem_post(&sem_p);
    }
}

void *pthread_p(void *arg)  //此線程打印ch的值
{
    while(1)
    {
        sem_wait(&sem_p);
        printf("%c",ch);
        fflush(stdout);
        sem_post(&sem_g);
    }
}

int main(int argc, char *argv[])
{
    pthread_t tid1,tid2;
    sem_init(&sem_g, 0, 0); // 初始化信號(hào)量為0
    sem_init(&sem_p, 0, 1); // 初始化信號(hào)量為1

    // 創(chuàng)建兩個(gè)線程
    pthread_create(&tid1, NULL, pthread_g, NULL);
    pthread_create(&tid2, NULL, pthread_p, NULL);

    // 回收線程
    pthread_join(tid1, NULL);
    pthread_join(tid2, NULL);

    return 0;
}

【信號(hào)量用于互斥】:

圖片

// 信號(hào)量用于互斥實(shí)例
#include < stdio.h >
#include < pthread.h >
#include < unistd.h >
#include < semaphore.h >

sem_t sem; //信號(hào)量

void printer(char *str)
{
    sem_wait(&sem);//減一,p操作
    while(*str) // 輸出字符串(如果不用互斥,此處可能會(huì)被其他線程入侵)
    {
        putchar(*str);  
        fflush(stdout);
        str++;
        sleep(1);
    }
    printf("n");

    sem_post(&sem);//加一,v操作
}

void *thread_fun1(void *arg)
{
    char *str1 = "hello";
    printer(str1);
}

void *thread_fun2(void *arg)
{
    char *str2 = "world";
    printer(str2);
}

int main(void)
{
    pthread_t tid1, tid2;

    sem_init(&sem, 0, 1); //初始化信號(hào)量,初始值為 1

    //創(chuàng)建 2 個(gè)線程
    pthread_create(&tid1, NULL, thread_fun1, NULL);
    pthread_create(&tid2, NULL, thread_fun2, NULL);

    //等待線程結(jié)束,回收其資源
    pthread_join(tid1, NULL);
    pthread_join(tid2, NULL); 

    sem_destroy(&sem); //銷毀信號(hào)量

    return 0;
}
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6847

    瀏覽量

    123424
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4338

    瀏覽量

    62738
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    505

    瀏覽量

    19705
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Linux下線程間通訊---讀寫條件變量

    讀寫,它把對(duì)共享資源的訪問者劃分成讀者和寫者,讀者只對(duì)共享資源進(jìn)行讀訪問,寫者則需要對(duì)共享資源進(jìn)行寫操作。件變量是線程可用的一種同步機(jī)制,條件變量
    的頭像 發(fā)表于 08-26 20:44 ?1506次閱讀
    Linux下線程間通訊---<b class='flag-5'>讀寫</b><b class='flag-5'>鎖</b>和<b class='flag-5'>條件</b><b class='flag-5'>變量</b>

    Linux高級(jí)編程---互斥

    在Linux系統(tǒng)里,有很多的應(yīng)用,包括互斥,文件,讀寫等等,
    發(fā)表于 01-13 10:07

    Linux驅(qū)動(dòng)開發(fā)筆記-自旋信號(hào)量

    :如果在寫代碼時(shí),有以上的競(jìng)態(tài)發(fā)生,一定要注意進(jìn)行互斥訪問7.解決競(jìng)態(tài)的方法:中斷屏蔽原子操作自旋信號(hào)量如何使用以上4個(gè)機(jī)制呢?1.中斷屏蔽解決哪些情況的競(jìng)態(tài):進(jìn)程和進(jìn)程的搶占中斷和
    發(fā)表于 08-30 18:08

    信號(hào)量、互斥自旋

    信號(hào)量、互斥、自旋http://bbs.edu118.com/forum.php?mod=viewthread&tid=488&from
    發(fā)表于 08-29 09:48

    芯靈思SinlinxA33開發(fā)板的Linux內(nèi)核信號(hào)量學(xué)習(xí)

    中解決并發(fā)控制的最常用方法是自旋信號(hào)量(絕大多數(shù)時(shí)候作為互斥使用)。自旋
    發(fā)表于 02-20 15:50

    信號(hào)量互斥的區(qū)別

    互斥用于線程的互斥,信號(hào)線用于線程的同步。這是互斥信號(hào)
    發(fā)表于 11-13 17:43 ?1.3w次閱讀
    <b class='flag-5'>信號(hào)量</b>和<b class='flag-5'>互斥</b><b class='flag-5'>鎖</b>的區(qū)別

    信號(hào)量自旋

    信號(hào)量時(shí),不可以再持有自旋。信號(hào)量基本使用形式為:static DECLARE_MUTEX(mr_sem);//聲明互斥
    發(fā)表于 04-02 14:43 ?811次閱讀

    深入了解互斥、條件變量、讀寫以及自旋

    C++11只包含其中的部分。接下來我主要通過pthread的API來展開本文。 mutex(互斥) mutex(mutual exclusive)即互斥
    的頭像 發(fā)表于 11-01 10:02 ?1902次閱讀

    Linux互斥的作用 互斥是什么

    1、互斥 互斥(mutex),在訪問共享資源之前對(duì)互斥進(jìn)行上鎖,在訪問完成后釋放
    的頭像 發(fā)表于 07-21 11:13 ?960次閱讀

    自旋互斥的區(qū)別有哪些

    自旋 自旋互斥很相似,在訪問共享資源之前對(duì)自旋
    的頭像 發(fā)表于 07-21 11:19 ?9517次閱讀

    讀寫的實(shí)現(xiàn)原理規(guī)則

    讀寫 互斥自旋要么是加鎖狀態(tài)、要么是不加鎖狀態(tài),而且一次只有一個(gè)線程可以對(duì)其加鎖。
    的頭像 發(fā)表于 07-21 11:21 ?926次閱讀
    <b class='flag-5'>讀寫</b><b class='flag-5'>鎖</b>的實(shí)現(xiàn)原理規(guī)則

    互斥不能在中斷中使用?

    互斥是一種特殊的二值信號(hào)量,因?yàn)樗鉀Q了優(yōu)先級(jí)翻轉(zhuǎn)的問題。
    的頭像 發(fā)表于 07-25 15:36 ?2681次閱讀

    互斥自旋的區(qū)別 自旋臨界區(qū)可以被中斷嗎?

    互斥自旋的區(qū)別 自旋臨界區(qū)可以被中斷嗎? 互斥
    的頭像 發(fā)表于 11-22 17:41 ?859次閱讀

    自旋互斥的使用場(chǎng)景是什么

    自旋互斥是兩種常見的同步機(jī)制,它們?cè)诙嗑€程編程中被廣泛使用。在本文中,我們將介紹自旋
    的頭像 發(fā)表于 07-10 10:05 ?1043次閱讀

    互斥自旋的實(shí)現(xiàn)原理

    互斥自旋是操作系統(tǒng)中常用的同步機(jī)制,用于控制對(duì)共享資源的訪問,以避免多個(gè)線程或進(jìn)程同時(shí)訪問同一資源,從而引發(fā)數(shù)據(jù)不一致或競(jìng)爭(zhēng)條件等問題
    的頭像 發(fā)表于 07-10 10:07 ?518次閱讀