博客
关于我
进程间同步
阅读量:594 次
发布时间:2019-03-12

本文共 1477 字,大约阅读时间需要 4 分钟。

进程间使用mutex实现数据同步:

#include 
#include
#include
#include
#include
#include
#include
#include
struct mt { int num; pthread_mutex_t mutex; pthread_mutexattr_t mutexattr;};int main(void){ int fd, i; struct mt *mm; pid_t pid; // 创建共享内存区域并初始化 // 以下代码用于创建并打开一个共享内存区段 // fd = open("mt_test", O_CREAT | O_RDWR, 0777); // ftruncate(fd, sizeof(*mm)); // mm = mmap(NULL, sizeof(*mm), PROT_READ|PROT_write, MAP_SHARED, fd, 0); // close(fd); // unlink("mt_test"); mm = mmap(NULL, sizeof(*mm), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANON, -1, 0); memset(mm, 0, sizeof(*mm)); // 初始化mutex属性并设置为进程共享 pthread_mutexattr_init(&mm->mutexattr); pthread_mutexattr_setpshared(&mm->mutexattr, PTHREAD_PROCESS_SHARE); // 初始化互斥锁 pthread_mutex_init(&mm->mutex, &mm->mutexattr); // 创建子进程 pid = fork(); if (pid == 0){ // 子进程执行 for (i = 0; i < 10; i++){ pthread_mutex_lock(&mm->mutex); mm->num++; printf("-child----num++ %d\n", mm->num); pthread_mutex_unlock(&mm->mutex); sleep(rand()%2 + 1); } } else if (pid > 0){ // 父进程执行 for (i = 0; i < 10; i++){ sleep(rand()%2); pthread_mutex_lock(&mm->mutex); mm->num += 2; printf("-parent---num+=2 %d\n", mm->num); pthread_mutex_unlock(&mm->mutex); } wait(NULL); // 等待子进程完成 } // 销毁锁和属性 pthread_mutexattr_destroy(&mm->mutexattr); pthread_mutex_destroy(&mm->mutex); munmap(mm, sizeof(*mm));}

运行结果展示过程中,父节点每次增加2,而子节点每次增加1,整个过程体现了进程间使用互斥锁实现的同步机制。这样可以确保在多进程环境下共享变量的访问是安全的。

转载地址:http://mznxz.baihongyu.com/

你可能感兴趣的文章
16 python基础-恺撒密码
查看>>
Frame--Api框架
查看>>
Boostrap技能点整理之【网格系统】
查看>>
新闻发布项目——业务逻辑层(UserService)
查看>>
hibernate正向生成数据库表以及配置——hibernate.cfg.xml
查看>>
javaWeb服务详解(含源代码,测试通过,注释) ——Emp的Dao层
查看>>
java实现人脸识别源码【含测试效果图】——Dao层(IUserDao)
查看>>
使用ueditor实现多图片上传案例——前台数据层(Index.jsp)
查看>>
ssm(Spring+Spring mvc+mybatis)——updateDept.jsp
查看>>
解决Chrome播放视频闪屏黑屏无法播放
查看>>
Git简单理解与使用
查看>>
echarts 基本图表开发小结
查看>>
制作JS验证码(简易)
查看>>
sklearn :ImportError: cannot import name ‘Imputer‘
查看>>
adb通过USB或wifi连接手机
查看>>
包装类
查看>>
JDK9-15新特性
查看>>
集合继承结构
查看>>
LinkedList 实现类
查看>>
Vector 实现类
查看>>