锁类型

相关函数原型:

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. MPP-编码示例

    了解MPP的基本功能后,接下来具体分析编码的代码.首先把编码的代码提取出来,方便以后的使用. 完整的编码代码如下,相比较给出的示例代码,做了一些改动,输入的指令全部去除,将函数入口改为利用OpenCV ...

  2. C语言货架01

    教材: < C程序设计(第四版) >  谭浩强著    清华大学出版社 教材目录 第1章     程序设计和C语言 第2章     算法——程序的灵魂 第3章     最简单的C程序设计— ...

  3. 导入虚拟机vmware,此主机支持Intel VT-x,但Intel VT-x处于禁用状态和黑屏

    解决方法:进入BIOS(按什么键进入bios,需要看你用什么电脑),把Intel Virtualization Technology         设置enabled 然后是黑屏解决方法:管理员模式 ...

  4. Pycharm安装并配置jupyter notebook

    Pycharm安装并配置jupyter notebook Pycharm安装并配置jupyter notebook 一: 安装命令jupyter: pip install jupyter 如果缺少依赖 ...

  5. 周一02.3运行python程序的两种方式

    一.运行python程序的两种方式 方法一:交互式:                     优点:输入一行代码立刻返回结果                      缺点:无法永久保存代码 方法二: ...

  6. kvm虚拟化

    1.kvm虚拟化介绍 什么是虚拟化 虚拟化就是通过模拟计算机硬件(cpu,内存,硬盘,网卡)来实现在一台物理服务器上运行同时多个不同的操作系统,并且使每个操作系统之间都是互相隔离的 为什么要学习虚拟化 ...

  7. 【alpha阶段】第八次Scrum Meeting

    每日任务内容 队员 昨日完成任务 明日要完成的任务 牛宇航 #26 评价总览接口编写https://github.com/rRetr0Git/rateMyCourse/issues/26 (任务较重, ...

  8. 类System

    System类简介: 在 System 类中提供了大量的静态方法,有标准输入.标准输出和错误输出流:对外部定义的属性和环境变量的访问:加载文件和库的方法:还有快速复制数组的一部分的实用方法. 常用方法 ...

  9. Collections算法类

    Collections类定义了一系列用于操作集合的静态方法. 常用方法: 1.sort():排序(默认是升序排列,降序实现方法) 如果ArrayList的泛型指定为String int等类型,可以通过 ...

  10. linux 下ab压力测试

    1.ab的简介 ab是apachebench命令的缩写. ab是apache自带的压力测试工具.ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试 ...