Linux多线程同步方法

来源:本站
导读:目前正在解读《Linux多线程同步方法》的相关信息,《Linux多线程同步方法》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《Linux多线程同步方法》的详细说明。
简介:本文主要介绍的是Linux多线程的几种同步方法

以下是线程的几种同步方式:

1、互斥量。

通过使用pthread的互斥接口保护数据,确保同一时间只有一个线程访问数据。互斥量从本质上讲是一把锁,在访问共享资源前对互斥量进行加锁,在访问完成后释放互斥量上的锁。如下例所示,就是互斥量对共享数据的操作:

#include#includeint value = 5;//共享变量pthread_mutex_t mutex;//互斥变量void *mythread1();void mainshow();int main(){int retval;pthread_t tid1;retval = pthread_create(&tid1,NULL,mythread1,&value);//创建线程if(retval != 0){printf(“Can not create mythread1n”);mainshow();retval = pthread_join(&tid1,NULL);//等待线程mythread1结束if(retval != 0){printf(“Can not join with mythread.n”);printf(“value = %dn”,value);return 0;}void *mythread1(){int retval;retval = pthread_mutex_lock(&mutex);//上锁value = value + 1;//对共享变量的操作printf("value = %dn",value);retval = pthread_mutex_unlock(&mutex);//解锁pthread_exit((void *)0);}void myshow(){int retval;retval = pthread_mutex_lock(&mutex);//上锁value = value + 1;//对共享变量的操作printf(“value = %dn”,value);pthread_mutex_unlock(&mutex);//解锁}

2、信号量

该信号量是Posix提供的基于内存的信号量,它们由应用程序分配信号量的内存空间。如下例所示,就是信号量对共享数据的操作:

#include#include#includeint 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 = %dn",value);return 0;}void *mythread(){int retval;retval = sem_wait(&sem1);value = value + 1;printf("value1 = %dn",value);retval = sem_post(&sem2);pthread_exit((void *) 0);}void mainshow(){int retval;retval = sem_wait(&sem2);value = value + 1;printf("value2 = %dn",value);retval = sem_post(&sem1);}

提醒:《Linux多线程同步方法》最后刷新时间 2024-03-14 01:04:48,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《Linux多线程同步方法》该内容的真实性请自行鉴别。