锁类型

相关函数原型:

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 进程间互斥锁实例的更多相关文章

  1. Mutex 进程间互斥

    学习Mutex的心得,不一定对,先记录一下. 同步技术分为两大类,锁定和信号同步. 锁定分为:Lock.Monitor 信号同步分为:AutoResetEvent.ManualResetEvent.S ...

  2. 网络编程并发 多进程 进程池,互斥锁,信号量,IO模型

    进程:程序正在执行的过程,就是一个正在执行的任务,而负责执行任务的就是cpu 操作系统:操作系统就是一个协调.管理和控制计算机硬件资源和软件资源的控制程序. 操作系统的作用: 1:隐藏丑陋复杂的硬件接 ...

  3. 20181229(守护进程,互斥锁,IPC,生产者和消费者模型)

    一.守护进程 守护进程:一个进程B守护另一个进程A,当被守护的进程A结束,进程B也就结束了.(不一定同生,但会同死) 两个特点: ①守护进程会在主进程代码执行结束后就终止 ②守护进程内无法再开启子进程 ...

  4. 并发编程 - 进程 - 1.互斥锁/2.模拟抢票/3.互斥锁与join区别

    1.互斥锁: 互斥锁:Lock 原理就是把并发变成串行,一个一个运行,不错乱,但效率低 保证多个进程修改一块数据时,大家是一个一个修改,不错乱 mutex.acquire() mutex.releas ...

  5. 守护进程,互斥锁,IPC,生产者与消费者模型

    守护进程: b 进程守护 a进程,当a进程执行完毕时,b进程会跟着立马结束 守护进程用途: 如果父进程结束了,子进程无需运行了,就可以将子进程设置为父进程的守护进程 例如我们qq视频聊天时,当我们退出 ...

  6. day34——僵尸进程和孤儿进程、互斥锁、进程之间的通信

    day34 僵尸进程和孤儿进程 基于unix环境(linux,macOS) 主进程需要等待子进程结束之后,主进程才结束 主进程时刻监测子进程的运行状态,当子进程结束之后,一段时间之内,将子进程进行回收 ...

  7. day35 守护进程、互斥锁、IPC

    day35 守护进程.互斥锁.IPC 1.守护进程 # 守护进程:当父进程执行完毕后,设置的守护进程也会跟着结束# 当一个进程被设置为守护进程后,其不能再产生子进程​ from multiproces ...

  8. 并发编程(二)——利用Process类开启进程、僵尸进程、孤儿进程、守护进程、互斥锁、队列与管道

    Process类与开启进程.守护进程.互斥锁 一.multiprocessing模块 1.multiprocessing模块用来开启子进程,并在子进程中执行我们定制的任务(比如函数),该模块与多线程模 ...

  9. [并发编程 - socketserver模块实现并发、[进程查看父子进程pid、僵尸进程、孤儿进程、守护进程、互斥锁、队列、生产者消费者模型]

    [并发编程 - socketserver模块实现并发.[进程查看父子进程pid.僵尸进程.孤儿进程.守护进程.互斥锁.队列.生产者消费者模型] socketserver模块实现并发 基于tcp的套接字 ...

随机推荐

  1. eslint 代码缩进 报错及解决

    一.背景 使用vue在VScode中正常写的代码,报了一堆的错误,仔细检查,发现都是缩进要么多了要么少了,总之是代码不规范的的报错. 二.原因 百度查了发现代码规范默认缩进2个空格,而VScode默认 ...

  2. Docker容器镜像删除

    好吧,本来认为删除镜像是一件很容易的事情,但刚开始上手,还是有点百思不得其解.删着删着,发现果然很容易.分享下本人的心得: 分两种情况:那么要删除镜像,首先得删除容器,删除容器时,确保容器已停止运行: ...

  3. RocketMQ知识整理与总结

    1.架构 RocketMQ的master broker与master broker没有任何消息通讯,nameserver之间也同样没有消息通信 MQ历史 由数据结构队列发展而来 MQ使用场景    异 ...

  4. 01-Redhat/Centos7网卡命名介绍及修改方式

    1. Redhat/Centos7网卡命名介绍 1.1 网络设备命名 Redhat/Centos7提供在网络接口中使用新的网络设备命名方法.这些功能会更改系统中的网络接口名称,以便定位和区分这些接口. ...

  5. Namespace讨论

    我们需要讨论一个深层次的问题: 为什么不直接在 tape17162c5-00 和 tapd568ba1a-74 上配置 Gateway IP,而是引入一个 namespace,在 namespace ...

  6. Python_if

    if if c语言中的if语句格式如下: if (条件) { 结果} python的格式与其不同,定义了自己的格式,更加的简明: if 条件 : 结果 print(111) if 3 > 2: ...

  7. Java的selenium代码随笔(6)

    //获取元素列表public List<WebElement> ListElements(WebElement webElement, By parentBy, By childrenBy ...

  8. CMDB(Configuration Management Database)资产管理系统和 运维自动化

    一.传统运维方式和自动化运维的区别 二.CMDB的介绍 三.CMDB的四种方式 四.项目的目录架构介绍以及配置文件的升级编写 五.比较low的项目架构书写 六.可插拔式收集资产 七.对收集的服务器信息 ...

  9. MySQL官网示例数据库emploees分析使用

    1.下载与安装 下载地址:https://github.com/datacharmer/test_db 安装博客:https://blog.csdn.net/appleyuchi/article/de ...

  10. dubbo框架的web端(war)和server端(tar.gz)结合jenkins打包方式

    一.web端程序,打包成war包 jenkins配置 1.项目名称,旧文件处理配置 2.参数构建配置 3.源码库配置 4.打包文件pom.xml配置及多环境打包传参,此处传参qa(表示打测试环境包,名 ...