⑴ linux的线程同步方式有哪些
三种同步方式:1、互斥锁(mutex)、2、条件同步(cond)、3、信号量(semphore).
如果还想深入:可以参考http://blog.csdn.net/zsf8701/article/details/7844316。
⑵ linux线程同步的互斥锁(mutex)到底怎么用的》谢谢
互斥锁(mutex) 通过锁机制实现线程间的同步。
1、初始化锁。在Linux下,线程的互斥量数据类型是pthread_mutex_t。在使用前,要对它进行初始化。
2、静态分配:pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
3、动态分配:int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutex_attr_t *mutexattr);
4、加锁。对共享资源的访问,要对互斥量进行加锁,如果互斥量已经上了锁,调用线程会阻塞,直到互斥量被解锁。
intpthread_mutex_lock(pthread_mutex*mutex);
intpthread_mutex_trylock(pthread_mutex_t*mutex);
解锁。在完成了对共享资源的访问后,要对互斥量进行解锁。
intpthread_mutex_unlock(pthread_mutex_t*mutex);
销毁锁。锁在是使用完成后,需要进行销毁以释放资源。
intpthread_mutex_destroy(pthread_mutex*mutex);
#include<cstdio>
#include<cstdlib>
#include<unistd.h>
#include<pthread.h>
#include"iostream"
usingnamespacestd;
pthread_mutex_tmutex=PTHREAD_MUTEX_INITIALIZER;
inttmp;
void*thread(void*arg)
{
cout<<"threadidis"<<pthread_self()<<endl;
pthread_mutex_lock(&mutex);
tmp=12;
cout<<"Nowais"<<tmp<<endl;
pthread_mutex_unlock(&mutex);
returnNULL;
}
intmain()
{
pthread_tid;
cout<<"mainthreadidis"<<pthread_self()<<endl;
tmp=3;
cout<<"Inmainfunctmp="<<tmp<<endl;
if(!pthread_create(&id,NULL,thread,NULL))
{
cout<<"Createthreadsuccess!"<<endl;
}
else
{
cout<<"Createthreadfailed!"<<endl;
}
pthread_join(id,NULL);
pthread_mutex_destroy(&mutex);
return0;
}
//编译:g++-othreadtestthread.cpp-lpthread
⑶ linux中,多线程互斥锁问题
线程一:
pthread_mutex_lock(&mutex);
线程一锁中做的事
pthread_mutex_unlock(&mutex);
线程一锁外做的事
线程二:
pthread_mutex_lock(&mutex);
线程二锁中做的事
pthread_mutex_unlock(&mutex);
线程二锁外做的事
当线程一二同时加锁时,只有一个获得锁(比如线程一),并开始处理锁中做的事,此时线程二被挂起。当线程一释放锁后,线程一将继续做锁外做的事,而线程二加锁做锁中做的事,再解锁做锁外做的事。
⑷ Linux中 条件变量为什么要用互斥锁来保护
你不管他是条件变量还是其他什么变量。只要理解,因为这个变量/资源是共享的,可能会有多个进程或线程去修改它,那么就必须为它添加一个锁,这个锁是每次只有一个进程/线程可以获取到的。
打个比方,
mutex是一个布尔型变量,表示这个资源变量(锁)的一个钥匙。
为真的是时候表示这个钥匙当前是可以借,
反之为假的时候表示已经有线程在使用这个钥匙。
在Java里边就用关键字synchronized来指定一个代码块一次只有一个线程可以访问。
取钥匙这个函数/方法的算法就可以这么理解了:如果这个锁可借,那么返回真,表示可借;否则返回假表示不可借
public synchronized boolean getmutex(){//取钥匙
if(mutex==true)//钥匙空闲可用
{
mutex=false;//取钥匙就进行修改,证明这一次取钥匙已经发生
return true;//返回真,表示取钥匙成功
}
else return false;//这个钥匙正在被使用,返回假表示去钥匙失败
}
就像一个公用电话亭,这就相当于规定了一次只允许一个人进门,你进去了就把门关上。门关着其他人就进不去了,只有你打完电话出来开门,释放这个锁,其他人才可以进去。
通过synchronized关键字将取钥匙跟进门两个动作放在在一起,绑在一块。
其中门就是条件变量,mutex就是这个门的互斥锁。