您的位置:首页 > 运维架构 > Linux

linux 多线程学习一:互斥

2016-05-17 20:51 465 查看
#include<iostream>
#include<pthread.h>
using namespace std;

pthread_t pt[2];
pthread_mutex_t mtx;
int num = 100;

void *func_thread(void* input)
{
while(1)
{
pthread_mutex_lock(&mtx);
if(num <= 0 || num >= 200)
pthread_exit(0);
cout<<"this is thread:"<<(char*)input <<endl;
if(0 == strcmp((char*)input,"thread1"))
{
num++;
}
else
{
num--;
}
cout<<"now num="<<num<<endl;
pthread_mutex_unlock(&mtx);
sleep(1);
}
}

int main()
{
pthread_create(&pt[0],NULL,func_thread,(void*)"thread1");
pthread_create(&pt[1],NULL,func_thread,(void*)"thread2");
pthread_join(pt[0],NULL);
pthread_join(pt[1],NULL);
return 0;
}

加入sleep的目的是防止资源一直被“thread1”占用

编译的时候要包含pthread库:

g++ thread_test.cpp -lpthread -o a.out

关于互斥锁我们主要可以用到下面3个函数(引自百度百科):

int pthread_mutex_lock(pthread_mutex_t *mutex)

int pthread_mutex_unlock(pthread_mutex_t *mutex)

int pthread_mutex_trylock(pthread_mutex_t *mutex)

pthread_mutex_trylock()语义与pthread_mutex_lock()类似,不同的是在锁已经被占据时返回EBUSY而不是挂起等待。

另外互斥锁还有动态和静态创建的区别,我这里采用的是静态创建,动态创建需要用到:

int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr)

int pthread_mutex_destroy(pthread_mutex_t *mutex)

其中pthread_mutexattr_t表示的是互斥锁的属性(引自百度百科):
互斥锁的属性在创建锁的时候指定,在LinuxThreads实现中仅有一个锁类型属性,不同的锁类型在试图对一个已经被锁定的互斥锁加锁时表现不同。
当前(glibc2.2.3,linuxthreads0.9)有四个值可供选择:

* PTHREAD_MUTEX_TIMED_NP,这是缺省值,也就是普通锁。当一个线程加锁以后,其余请求锁的线程将形成一个等待队列,并在解锁后按优先级获得锁。这种锁策略保证了资源
分配的公平性。

* PTHREAD_MUTEX_RECURSIVE_NP,嵌套锁,允许同一个线程对同一个锁成功获得多次,并通过多次unlock解锁。如果是不同线程请求,则在加锁线程解锁时重新竞争。

* PTHREAD_MUTEX_ERRORCHECK_NP,检错锁,如果同一个线程请求同一个锁,则返回EDEADLK,否则与PTHREAD_MUTEX_TIMED_NP类型动作相同。这样就保证当不允许多次加锁时不会
出现最简单情况下的死锁。

* PTHREAD_MUTEX_ADAPTIVE_NP,适应锁,动作最简单的锁类型,仅等待解锁后重新竞争。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: