互斥量,线程互斥

Posix互斥锁被声明为具有      pthread_mutex_t     数据类型的变量。
  
        如果互斥锁变量是 静态分配 的,那么可以使用 PTHREAD_MUTEX_INITIALIZER 来进行初始化。
        如果互斥锁变量是 动态分配 的,那么就应该用 pthread_mutex_init 来进行初始化。

        初始化::
                      #include <pthread.h>
                      int pthread_mutex_init(pthread_mutex_t *,pthread_mutexattr_t *);  //默认第二个参数是NULL
                      或
                      PTHREAD_MUTEX_INITIALIZER
          


        销毁::
                     #include <pthread.h>
                     int pthread_mutex_destroy(pthread_mutex_t *);



       互斥锁上锁::
                       #include <pthread.h>
                       int pthread_mutex_lock(pthread_mutex_t *);
                       int pthread_mutex_trylock(pthread_mutex_t *);

        
        互斥锁解锁::
                        #include <pthread.h>
                        int prhead_mutex_unlock(pthread_mutex_t *);


阻塞加锁pthread_mutex_lock::
        如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_lock将阻塞,直到该互斥锁解锁为止。

非阻塞加锁pthread_mutex_trylock::
        如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_trylock将立即返回,并返回错误码在errno中,为EBUSY。

        (当有多个线程互斥加锁阻塞在同一个地方时,当锁被释放时,优先释放优先级最高的线程)


       尽管我们说互斥锁保护的是临界区,实际上保护的是临界区中被操作的数据(data)。


由于pthread_mutex_t几乎不占资源,所以一般destroy函数很少去调用,一般用于判断互斥量的状态。



下面是关于互斥量上锁和解锁的例子;

#include <iostream>
#include <pthread.h>
 
using namespace std;
 
pthread_mutex_t mutex; //~ 创建互斥锁mutex
int share = 0; //~ 共享数据
 
//~ 线程入口
void * thread_function(void *arg)
{
	const int N = 1000000;
	for(int i = 0; i < N; ++i)
	{
		//~ 访问共享数据
		pthread_mutex_lock(&mutex);
		share++;
		pthread_mutex_unlock(&mutex);
	}
}
int
main()
{
	pthread_mutex_init(&mutex, NULL); //~ 初始化互斥锁mutex
	pthread_t thread_id;
	void *exit_status;
	pthread_create(&thread_id, NULL, thread_function, NULL); //~ 创建新线程
	for(int i = 0; i < 10; ++i)
	{
		usleep(10000); //~ 延时10ms
		//~ 访问共享数据
		pthread_mutex_lock(&mutex);
		cout<<share<<endl;
		pthread_mutex_unlock(&mutex);
	}
	pthread_join(thread_id, &exit_status); //~ 等待线程结束
	pthread_mutex_destroy(&mutex); //~ 销毁互斥锁
	return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值