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的套接字 ...
随机推荐
- eslint 代码缩进 报错及解决
一.背景 使用vue在VScode中正常写的代码,报了一堆的错误,仔细检查,发现都是缩进要么多了要么少了,总之是代码不规范的的报错. 二.原因 百度查了发现代码规范默认缩进2个空格,而VScode默认 ...
- Docker容器镜像删除
好吧,本来认为删除镜像是一件很容易的事情,但刚开始上手,还是有点百思不得其解.删着删着,发现果然很容易.分享下本人的心得: 分两种情况:那么要删除镜像,首先得删除容器,删除容器时,确保容器已停止运行: ...
- RocketMQ知识整理与总结
1.架构 RocketMQ的master broker与master broker没有任何消息通讯,nameserver之间也同样没有消息通信 MQ历史 由数据结构队列发展而来 MQ使用场景 异 ...
- 01-Redhat/Centos7网卡命名介绍及修改方式
1. Redhat/Centos7网卡命名介绍 1.1 网络设备命名 Redhat/Centos7提供在网络接口中使用新的网络设备命名方法.这些功能会更改系统中的网络接口名称,以便定位和区分这些接口. ...
- Namespace讨论
我们需要讨论一个深层次的问题: 为什么不直接在 tape17162c5-00 和 tapd568ba1a-74 上配置 Gateway IP,而是引入一个 namespace,在 namespace ...
- Python_if
if if c语言中的if语句格式如下: if (条件) { 结果} python的格式与其不同,定义了自己的格式,更加的简明: if 条件 : 结果 print(111) if 3 > 2: ...
- Java的selenium代码随笔(6)
//获取元素列表public List<WebElement> ListElements(WebElement webElement, By parentBy, By childrenBy ...
- CMDB(Configuration Management Database)资产管理系统和 运维自动化
一.传统运维方式和自动化运维的区别 二.CMDB的介绍 三.CMDB的四种方式 四.项目的目录架构介绍以及配置文件的升级编写 五.比较low的项目架构书写 六.可插拔式收集资产 七.对收集的服务器信息 ...
- MySQL官网示例数据库emploees分析使用
1.下载与安装 下载地址:https://github.com/datacharmer/test_db 安装博客:https://blog.csdn.net/appleyuchi/article/de ...
- dubbo框架的web端(war)和server端(tar.gz)结合jenkins打包方式
一.web端程序,打包成war包 jenkins配置 1.项目名称,旧文件处理配置 2.参数构建配置 3.源码库配置 4.打包文件pom.xml配置及多环境打包传参,此处传参qa(表示打测试环境包,名 ...