新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > Linux多线程同步方法

Linux多线程同步方法

作者:时间:2011-08-11来源:网络收藏

以下是的几种方式:

本文引用地址:http://www.eepw.com.cn/article/150368.htm

1、 互斥量。

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

#include stdio.h>
#include pthread.h>
int 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 stdio.h>
#include pthread.h>
#include semaphore.h>
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 = %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操作系统文章专题:linux操作系统详解(linux不再难懂)

linux相关文章:linux教程




关键词: 方法 同步 线程 Linux

评论


相关推荐

技术专区

关闭