线程、进程通信---mutex=>互斥锁

             互斥锁用来保证一段时间内只有一个线程在执行一段代码。必要性显而易见:假设各个线程向同一个文件顺序写入数据,
最后得到的结果一定是灾难性的。我们先看下面一段代码。这是一个读/写程序,它们公

用一个缓冲区,并且我们假定一个缓冲区只能保存一条信息。即缓冲区只有两个状态:有信息或没有信息。

(pthread_delay_np 这个函数只在 POSIX Threads for Window里面有,在其他的平台上是没有实现的。函数 sleep、usleep 以及nanosleep都是阻塞当前的进程,那么属于该进程的所有的线程都将被阻塞。在 Linux 上之所以 sleep 这些函数阻塞的是当前线程而不阻塞当前进程,是因为在 linux 上是用进程模拟线程的。)


voidreader_function ( void );
void writer_function ( void );
char  buffer;
int buffer_has_item=0;
pthread_mutex_t mutex;
struct timespec delay;
void main ( void ){
pthread_t reader;
delay.tv_sec = 2;
delay.tv_nec = 0;
pthread_mutex_init (&mutex,NULL);
pthread_create(&reader, pthread_attr_default, (void*)&reader_function),NULL);
writer_function( );
}
void writer_function (void){
while(1){
pthread_mutex_lock (&mutex);
if (buffer_has_item==0){
buffer=make_new_item( );
buffer_has_item=1;
}
pthread_mutex_unlock(&mutex);
pthread_delay_np(&delay);
}}
void  reader_function(void){
while(1){
pthread_mutex_lock(&mutex);
if(buffer_has_item==1){
consume_item(buffer);
buffer_has_item=0;
}
pthread_mutex_unlock(&mutex);
pthread_delay_np(&delay);
}
}


这里声明了互斥锁变量 mutex,结构 pthread_mutex_t 为不公开的数据类型,其中包含一个系统分配的属性对象。函数
pthread_mutex_init 用来生成一个互斥锁。NULL 参数表明使用默认属性。如果需要声明特定属性的互斥锁,须调用函数
pthread_mutexattr_init。


函数 pthread_mutexattr_setpshared 和函数pthread_mutexattr_settype 用来设置互斥锁属性。

前一个函数设置属性pshared,它有两个取值,PTHREAD_PROCESS_PRIVATE 和 PTHREAD_PROCESS_SHARED。
前者用来不同进程中的线程同步,后者用于同步本进程的不同线程。在上面的例子中,我们使用的是默认属性
PTHREAD_PROCESS_PRIVATE。后者用来设置互斥锁类型,可选的类型有
PTHREAD_MUTEX_NORMAL、PTHREAD_MUTEX_ERRORCHECK、PTHREAD_MUTEX_RECURSIVE 和 PTHREAD_MUTEX_DEFAULT。它们分别定义了不同的上所、解锁机制,一般情况下,选用最后一个默认属性。


pthread_mutex_lock 声明开始用互斥锁上锁,此后的代码直至调用 pthread_mutex_unlock 为止,均被上锁,即同一时间只能被一个线程调用执行。

当一个线程执行到 pthread_mutex_lock处时,如果该锁此时被另一个线程使用,那此线程被阻塞,即程序将等待到另一个线程释放此互斥锁。在上面的例子中,我们使用了pthread_delay_np 函数,让线程睡眠一段时间,就是为了防止一个线程始终占据此函数。


          上面的例子非常简单,就不再介绍了,需要提出的是在使用互斥锁的过程中很有可能会出现死锁:两个线程试图同时占用两个资源,并按不同的次序锁定相应的互斥锁,例如两个线程都需要锁定互斥锁 1 和互斥锁 2,a 线程先锁
定互斥锁 1,b 线程先锁定互斥锁 2,这时就出现了死锁。此时我们可以使用函数pthread_mutex_trylock,它是函数 pthread_mutex_lock 的非阻塞版本,当它发现死锁不可避免时,它会返回相应的信息,程序员可以针对死锁做出相应的处理。另外不同的互斥锁类型对死锁的处理不一样,但最主要的还是要程序员自己在程序设计注意这一点。






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值