pthread mutex 进程间互斥锁实例
锁类型
相关函数原型:
int pthread_mutexattr_settype (pthread_mutexattr_t *attr, int kind);
int pthread_mutexattr_gettype (const pthread_mutexattr_t *attr, int *kind);
kind 取值:
| 值 | 定义 | 别名 | 描述 |
| 0 | PTHREAD_MUTEX_TIMED_NP | PTHREAD_MUTEX_NORMAL | 普通锁,默认值,加锁后任何其他或本线程的加锁都会阻塞 |
| 1 | PTHREAD_MUTEX_RECURSIVE_NP | PTHREAD_MUTEX_RECURSIVE | 嵌套锁,允许同线程内对同一个锁加锁多次,记录加锁次数 |
| 2 | PTHREAD_MUTEX_ERRORCHECK_NP | PTHREAD_MUTEX_ERRORCHECK | 检错锁,禁止同线程内对同一个锁加锁多次 |
| 3 | PTHREAD_MUTEX_ADAPTIVE_NP | 适应锁,效率更高,等同于多次trylock() + PTHREAD_MUTEX_TIMED_NP |
#include <stdio.h>
#include <pthread.h> pthread_mutex_t mutex; int main(int argc, char* argv[])
{
//初始化锁类型
pthread_mutexattr_t mutex_attr;
pthread_mutexattr_init(&mutex_attr);
pthread_mutexattr_settype(&mutex_attr, PTHREAD_MUTEX_TIMED_NP); //初始化锁
pthread_mutex_init(&mutex, &mutex_attr); //..业务处理... return ;
}
实例
进程间锁
相关函数原型:
int pthread_mutexattr_setpshared (pthread_mutexattr_t *attr, int pshared);
int pthread_mutexattr_getpshared (const pthread_mutexattr_t *attr, int *pshared);
pshared 取值:
| 值 | 定义 | 描述 |
| 0 | PTHREAD_PROCESS_PRIVATE | 进程内互斥锁,仅可当前进程内共享 |
| 1 | PTHREAD_PROCESS_SHARED | 进程间互斥锁,多个进程间共享 |
第一个程序代码
#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <sys/mman.h>
#include <fcntl.h>
#include <string.h>
#include <sys/stat.h> int main(int argc, const char* argv[])
{
char mmap_file_path[] = { };
getcwd(mmap_file_path, sizeof(mmap_file_path));
strcat(mmap_file_path, "/pthread_shared"); pthread_mutex_t* mutex_ptr = NULL; int fd = open(mmap_file_path, O_RDWR | O_CREAT, );
if ( < fd)
{
//重置文件大小
ftruncate(fd, sizeof(pthread_mutex_t)); mutex_ptr = (pthread_mutex_t*)mmap(, sizeof(pthread_mutex_t), PROT_READ | PROT_WRITE, MAP_SHARED, fd, ); close(fd);
}
else
{
printf("open err\n");
} if (NULL != mutex_ptr)
{
//初始化锁对象
pthread_mutexattr_t attr;
pthread_mutexattr_init(&attr);
pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED);
pthread_mutex_init(mutex_ptr, &attr); int lock_ret = pthread_mutex_lock(mutex_ptr); if ( == lock_ret)
{
printf("lock successed\n");
usleep( * * );
pthread_mutex_unlock(mutex_ptr);
}
else
{
printf("lock failed: %d\n", lock_ret);
}
} return ;
}
实例-第一个程序
第二个程序代码,特殊处在获取锁对象后不需要初始化,因为在第一个进程内已经初始化了
#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <sys/mman.h>
#include <fcntl.h>
#include <string.h> int main(int argc, const char* argv[])
{
char mmap_file_path[] = { };
getcwd(mmap_file_path, sizeof(mmap_file_path));
strcat(mmap_file_path, "/pthread_shared"); pthread_mutex_t* mutex_ptr = NULL; int fd = open(mmap_file_path, O_RDWR | O_CREAT, );
if ( < fd)
{
mutex_ptr = (pthread_mutex_t*)mmap(, sizeof(pthread_mutex_t), PROT_READ | PROT_WRITE, MAP_SHARED, fd, ); close(fd);
}
else
{
printf("open err\n");
} if (NULL != mutex_ptr)
{
int lock_ret = pthread_mutex_lock(mutex_ptr); if ( == lock_ret)
{
printf("lock successed\n");
usleep( * * ); pthread_mutex_unlock(mutex_ptr);
}
else
{
printf("lock failed: %d\n", lock_ret);
}
} return ;
}
实例-第二个程序
锁优先级
设置持有互斥量的线程的优先级上限。相关函数的原型:
int pthread_mutexattr_setprioceiling (pthread_mutexattr_t *attr, int prioceiling);
int pthread_mutexattr_getprioceiling (const pthread_mutexattr_t *attr, int *prioceiling);
Linux 上 prioceiling 取值范围 [1, 99],值越大级别越高。
锁协议
相关函数的原型:
int pthread_mutexattr_setprotocol (pthread_mutexattr_t *attr, int protocol);
int pthread_mutexattr_getprotocol (const pthread_mutexattr_t *attr, int *protocol);
protocol取值
| 值 | 定义 | 描述 |
| 0 | PTHREAD_PRIO_NONE | 不改变线程的优先级属性 |
| 1 | PTHREAD_PRIO_INHERIT | 递归的,持有锁的线程,将提升优先级至被该锁阻塞的其他线程里的最高优先级 |
| 2 | PTHREAD_PRIO_PROTECT | 以线程本身优先级和持有锁的优先级的最高者运行,无论是否有其他线程在等待该锁 |
锁健壮性
相关函数的原型:
int pthread_mutexattr_setrobust_np (pthread_mutexattr_t *attr, int robustness);
int pthread_mutexattr_getrobust_np (const pthread_mutexattr_t *attr, int *robustness);
robustness 取值
| 值 | 定义 | 描述 |
| 0 | PTHREAD_MUTEX_STALLED_NP | 如果互斥锁的属主死亡,则以后对 pthread_mutex_lock() 的所有调用将以不确定的方式被阻塞 |
| 1 | PTHREAD_MUTEX_ROBUST_NP | 互斥锁的属主死亡时,将会解除锁定该互斥锁。互斥锁的下一个属主将获取该互斥锁,并返回错误EOWNWERDEAD |
pthread mutex 进程间互斥锁实例的更多相关文章
- Mutex 进程间互斥
学习Mutex的心得,不一定对,先记录一下. 同步技术分为两大类,锁定和信号同步. 锁定分为:Lock.Monitor 信号同步分为:AutoResetEvent.ManualResetEvent.S ...
- 网络编程并发 多进程 进程池,互斥锁,信号量,IO模型
进程:程序正在执行的过程,就是一个正在执行的任务,而负责执行任务的就是cpu 操作系统:操作系统就是一个协调.管理和控制计算机硬件资源和软件资源的控制程序. 操作系统的作用: 1:隐藏丑陋复杂的硬件接 ...
- 20181229(守护进程,互斥锁,IPC,生产者和消费者模型)
一.守护进程 守护进程:一个进程B守护另一个进程A,当被守护的进程A结束,进程B也就结束了.(不一定同生,但会同死) 两个特点: ①守护进程会在主进程代码执行结束后就终止 ②守护进程内无法再开启子进程 ...
- 并发编程 - 进程 - 1.互斥锁/2.模拟抢票/3.互斥锁与join区别
1.互斥锁: 互斥锁:Lock 原理就是把并发变成串行,一个一个运行,不错乱,但效率低 保证多个进程修改一块数据时,大家是一个一个修改,不错乱 mutex.acquire() mutex.releas ...
- 守护进程,互斥锁,IPC,生产者与消费者模型
守护进程: b 进程守护 a进程,当a进程执行完毕时,b进程会跟着立马结束 守护进程用途: 如果父进程结束了,子进程无需运行了,就可以将子进程设置为父进程的守护进程 例如我们qq视频聊天时,当我们退出 ...
- day34——僵尸进程和孤儿进程、互斥锁、进程之间的通信
day34 僵尸进程和孤儿进程 基于unix环境(linux,macOS) 主进程需要等待子进程结束之后,主进程才结束 主进程时刻监测子进程的运行状态,当子进程结束之后,一段时间之内,将子进程进行回收 ...
- day35 守护进程、互斥锁、IPC
day35 守护进程.互斥锁.IPC 1.守护进程 # 守护进程:当父进程执行完毕后,设置的守护进程也会跟着结束# 当一个进程被设置为守护进程后,其不能再产生子进程 from multiproces ...
- 并发编程(二)——利用Process类开启进程、僵尸进程、孤儿进程、守护进程、互斥锁、队列与管道
Process类与开启进程.守护进程.互斥锁 一.multiprocessing模块 1.multiprocessing模块用来开启子进程,并在子进程中执行我们定制的任务(比如函数),该模块与多线程模 ...
- [并发编程 - socketserver模块实现并发、[进程查看父子进程pid、僵尸进程、孤儿进程、守护进程、互斥锁、队列、生产者消费者模型]
[并发编程 - socketserver模块实现并发.[进程查看父子进程pid.僵尸进程.孤儿进程.守护进程.互斥锁.队列.生产者消费者模型] socketserver模块实现并发 基于tcp的套接字 ...
随机推荐
- linux 命令基础大全
pwd:显示当前路径 cd :切换目录 用法:cd cd ../ 切换到上级目录 cd / 切换到根目录 cd ~ (或只有cd )切换到当前用户主目录(home底下以用户名命名的文件夹) /r ...
- DVWA-暴力破解学习笔记
DVWA-暴力破解 1.暴力破解 2.burp安装证书 3.万能密码 一.暴力破解 burp四种暴力破解类型: sniper 一个字典,两个参数,先匹配第一项再匹配第二项 Battering ra ...
- Exception in thread "main" org.I0Itec.zkclient.exception.ZkAuthFailedException: Authentication failure is thrown while creating kafka topic
Exception in thread "main" org.I0Itec.zkclient.exception.ZkAuthFailedException: Authentica ...
- python+selenium运行时,提示元素不可见
python+selenium运行多次新增项目脚本(出错的元素通过by_id的方式定位),当第三次新增时报Message: element not visible的错误,加入等待时间,等页面加载完成, ...
- EntityFramework 6.x和EntityFramework Core关系映射中导航属性必须是public?
前言 不知我们是否思考过一个问题,在关系映射中对于导航属性的访问修饰符是否一定必须为public呢?如果从未想过这个问题,那么我们接下来来探讨这个问题. EF 6.x和EF Core 何种情况下必须配 ...
- Python--day06(深浅拷贝、元组、字典、集合)
1. 深浅拷贝 1.1 值拷贝 s1直接将ls中存放的地址拿过来s1内部的值发生任何变化,s2都会随之变化 s1 = ['1','2','3','a']s2 = s1print(id(s1),id ...
- Linux操作系统计划任务
++++++++++++++++++++++++++++++++++++++++++++++++标题:Linux操作系统的计划任务内容:计划任务分为单次任务和周期性任务,周期任务分为系统级计划任务和用 ...
- Bayes factor
bayes因子为什么一定要除以先验机会比,如果是想用样本的作用,来判断支持原来的假设θ_0,H_0的力度,直接用后验概率比不就好了吗? 左边等于右边
- C++通用WMI接口实现获取Windows操作系统内核版本号
作为一名Windows开发者,能熟练掌握WMI技术,在开发Windows应用程序的时候往往能够事半功倍.今天来给大家分享一个使用WMI来获取Windows操作系统内核版本号的例子. 首先我们打开WMI ...
- AOP - 2 实例(SpringBoot 注解方式)
1.创建Spring Boot项目 创建一个Spring Boot 项目,然后pom中引入web 模块与AOP相关依赖. <dependency> <groupId>org.s ...