mutex锁是线程间互斥还是进程间互斥
答案:2 悬赏:50
解决时间 2021-04-21 05:54
- 提问者网友:你在我眼中是最帅
- 2021-04-20 19:52
mutex锁是线程间互斥还是进程间互斥
最佳答案
- 二级知识专家网友:迷人小乖乖
- 2021-04-20 21:05
pthread_mutex可以进行线程间同步(默认),也可以进行进程间同步(调用pthread_mutexattr_setpshared并设置参数为PTHREAD_PROCESS_SHARED)。在进程间同步的时候把mutex放在共享内存中,使得多个进程可以访问到同一个mutex对象
全部回答
- 1楼网友:桃花别处起长歌
- 2021-04-20 21:28
互斥锁(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、加锁。对共享资源的访问,要对互斥量进行加锁,如果互斥量已经上了锁,调用线程会阻塞,直到互斥量被解锁。
int pthread_mutex_lock(pthread_mutex *mutex);
int pthread_mutex_trylock(pthread_mutex_t *mutex);
解锁。在完成了对共享资源的访问后,要对互斥量进行解锁。
int pthread_mutex_unlock(pthread_mutex_t *mutex);
销毁锁。锁在是使用完成后,需要进行销毁以释放资源。
int pthread_mutex_destroy(pthread_mutex *mutex);
#include
#include
#include
#include
#include "iostream"
using namespace std;
pthread_mutex_t mutex = pthread_mutex_initializer;
int tmp;
void* thread(void *arg)
{
cout << "thread id is " << pthread_self() << endl;
pthread_mutex_lock(&mutex);
tmp = 12;
cout << "now a is " << tmp << endl;
pthread_mutex_unlock(&mutex);
return null;
}
int main()
{
pthread_t id;
cout << "main thread id is " << pthread_self() << endl;
tmp = 3;
cout << "in main func tmp = " << tmp << endl;
if (!pthread_create(&id, null, thread, null))
{
cout << "create thread success!" << endl;
}
else
{
cout << "create thread failed!" << endl;
}
pthread_join(id, null);
pthread_mutex_destroy(&mutex);
return 0;
}
//编译:g++ -o thread testthread.cpp -lpthread
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯