在線程對(duì)共享相同內(nèi)存操作時(shí),就會(huì)出現(xiàn)多個(gè)線程對(duì)同一資源的使用,為此,需要對(duì)這些線程進(jìn)行同步,以確保它們?cè)谠L問共享內(nèi)存的時(shí)候不會(huì)訪問到無效的數(shù)值。
以下是線程的幾種同步方式:
1、 互斥量。
通過使用pthread的互斥接口保護(hù)數(shù)據(jù),確保同一時(shí)間只有一個(gè)線程訪問數(shù)據(jù)。互斥量從本質(zhì)上講是一把鎖,在訪問共享資源前對(duì)互斥量進(jìn)行加鎖,在訪問完成后釋放互斥量上的鎖。如下例所示,就是互斥量對(duì)共享數(shù)據(jù)的操作:
}
2、信號(hào)量
該信號(hào)量是Posix提供的基于內(nèi)存的信號(hào)量,它們由應(yīng)用程序分配信號(hào)量的內(nèi)存空間。如下例所示,就是信號(hào)量對(duì)共享數(shù)據(jù)的操作:
#include
#include
#include
int value = 5;
sem_t sem1,sem2;
void mainshow();
void *mythread();
int main()
{
int retval;
pthread_t tid;
retval = sem_init(&sem1,0,0);
retval = sem_init(&sem2,0,1);
retval =pthread_create(&tid,NULL,mythread,NULL);
mainshow();
pthread_join(tid,NULL);
printf(“value3 = %d\n”,value);
return 0;
}
void *mythread()
{
int retval;
retval = sem_wait(&sem1);
value = value + 1;
printf(“value1 = %d\n”,value);
retval = sem_post(&sem2);
pthread_exit((void *) 0);
}
void mainshow()
{
int retval;
retval = sem_wait(&sem2);
value = value + 1;
printf(“value2 = %d\n”,value);
retval = sem_post(&sem1);
}
責(zé)任編輯:gt
-
數(shù)據(jù)
+關(guān)注
關(guān)注
8文章
7233瀏覽量
90788 -
線程
+關(guān)注
關(guān)注
0文章
507瀏覽量
20041
發(fā)布評(píng)論請(qǐng)先 登錄
Rust的多線程編程概念和使用方法
python創(chuàng)建多線程的兩種方法
如何使用多線程和異步操作等并發(fā)設(shè)計(jì)方法來最大化程序的性能
QNX環(huán)境下多線程編程
Linux多線程同步方法
設(shè)計(jì)多線程和多核系統(tǒng)

java多線程同步方法
多線程好還是單線程好?單線程和多線程的區(qū)別 優(yōu)缺點(diǎn)分析
三種Linux中的常用多線程同步方式淺析

python創(chuàng)建多線程的兩種方法
多線程同步的幾種方法
多線程如何保證數(shù)據(jù)的同步
java實(shí)現(xiàn)多線程的幾種方式
Python中多線程和多進(jìn)程的區(qū)別

評(píng)論