锁类型

相关函数原型:

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. SQL Server数据库文件与文件组总结

    文件和文件组概念 关于文件与文件组,简单概括如下,详情请参考官方文档"数据库文件和文件组Database Files and Filegroups"或更多相关资料: 数据文件概念: ...

  2. sql Server 创建临时表 嵌套循环 添加数据

    begin --通过销货单与明细,生成安装项目及明细,及判断明细是否拆分生成多条 --delete from sazxm --delete from ssbazrw --获取未生成项目的销货单号 ,) ...

  3. python3 字符串/列表/元组(str/list/tuple)相互转换方法及join()函数的使用

    在抓取网络数据的时候,有时会用正则对结构化的数据进行提取,比如 href="https://www.1234.com"等.python的re模块的findall()函数会返回一个所 ...

  4. Ubuntu 16.04 安装垃圾清理工具 BleachBit

    BleachBit 可以清理系统缓存文件, 清理磁盘垃圾. 首先下载最新版 deb安装包,默认下载到Downloads 中, 下载链接: https://www.bleachbit.org/downl ...

  5. C# -- FTP上传下载

    C# -- FTP上传下载 1. C#实现FTP下载 private static void TestFtpDownloadFile(string strFtpPath, string strFile ...

  6. mange

    from flask import Flask app = Flask(__name__) manager = Manager(app) 1. 重写Command class ShellCommand ...

  7. 使用栈实现队列(1)(Java)

    class MyQueue { private Stack s1; private Stack s2; public MyQueue(int size) { this.s1 = new Stack(s ...

  8. 如何把Office365的更新从半年通道改成月度通道

    转自msdn,转发链接:www.cnblogs.com/Charltsing/p/Office365month.html 作者QQ: 564955427 建立一个Bat文件,写入 下面内容 setlo ...

  9. python面对对象(不全解)

    面对对象:以人类为例,人类通用功能:吃喝拉撒,就可以封装成一个类,不同功能:嫖赌毒,就是对象的不同功能.继承,多态… 上码 class Person(object): def __init__(sel ...

  10. windows一键安装包的升级禅道

    如果你现在使用的是windows xampp 集成运行环境,那么请按照下面的步骤进行: 一.升级步骤: 下载新的源代码包(zip格式).(注意,不是.exe的集成运行环境,如果你下载这个,会造成数据被 ...