IO进程:信号灯集

news2024/10/1 1:20:46

程序代码:

sem.h:

  1 #ifndef __SEM_H__
  2 #define __SEM_H__
  3 
  4 //创建信号灯集并初始化,semcount表示灯个数
  5 int open_sem(int semcount);
  6 
  7 //申请资源操作,semno表示灯的编号
  8 int P(int semid,int semno);
  9 
 10 //释放资源操作,semno表示灯的编号
 11 int V(int semid,int semno);
 12 
 13 //删除信号灯集
 14 int del_sem(int semid);
 15 
 16 #endif                                                                                            
~             

sem.c:

  1 #include<myhead.h>
  2 union semun
  3 {
  4     int val;
  5     struct semid_ds *buf;
  6     unsigned short *array;
  7     struct seminfo *__buf;
  8 };
  9 //定义给信号灯集中的指定信号灯赋值
 10 int init_semno(int semid,int semno)
 11 {
 12     union semun buf;
 13     printf("请输入要给编号为%d的灯设置的值:",semno);
 14     scanf("%d",&buf.val);
 15     //调用控制函数
 16     if(semctl(semid,semno,SETVAL,buf)==-1)
 17     {
 18         perror("semctl error");
 19         return -1;
 20     }
 21     return 0;
 22 }
 23 //创建或打开共享内存,参数为要申请的信号灯集中包含的灯的个数,返回值信号灯集的id
 24 int open_sem(int semcount)
 25 {
 26     //创建key值
 27     key_t key=-1;
 28     if((key=ftok("/",'s'))==-1)
 29     {
 30         perror("ftok error");
 31         return -1;
 32     }
 33     //通过key值创建一个信号灯集
 34     int semid=-1;
 35     if((semid=semget(key,semcount,IPC_CREAT|IPC_EXCL|0664))==-1)
 36     {
 37         //对错误码判断,EEXIST,说明信号灯集已存在
 38         if(errno==EEXIST)
 39         {
 40             //直接打开信号灯集即可
 41             semid=semget(key,semcount,IPC_CREAT|0664);
 42             return semid;
 43         }
 44         perror("semget error");
 45         return -1;
 46     }
 47     //给信号灯集的每个灯进行初始化操作
 48     for(int i=0;i<semcount;i++)
 49     {
 50         //对编号为i的灯进行初始化
 51         init_semno(semid,i);
 52     }
 53     return semid;
 54 }
 55 //进行申请资源操作,参数要申请的信号灯id,以及灯的编号
 56 int P(int semid,int semno)
 57 {
 58     //定义要执行操作的结构体变量
 59     struct sembuf buf;
 60     buf.sem_num=semno;
 61     buf.sem_op=-1;//申请资源
 62     buf.sem_flg=0;//阻塞方式申请
 63     //执行函数
 64     if(semop(semid,&buf,1)==-1)
 65     {
 66         perror("P error");
 67         return -1;
 68     }
 69     return 0;
 70 }
 71 //进行释放资源操作,参数为要申请的信号灯id,以及灯的编号
 72 int V(int semid,int semno)
 73 {
 74     struct sembuf buf;
 75     buf.sem_num=semno;
 76     buf.sem_op=1;
 77     buf.sem_flg=0;
 78     if(semop(semid,&buf,1)==-1)
 79     {
 80         perror("V error");
 81         return -1;
 82     }
 83     return 0;
 84 }
 85 //删除信号灯集的操作,参数为要删除的信号灯集
 86 int del_sem(int semid)
 87 {
 88     //删除信号灯集
 89     if(semctl(semid,0,IPC_RMID)==-1)                                                                                                                                                                                                                                         
 90     {
 91         perror("delete error");
 92         return -1;
 93     }
 94     return 0;
 95 }
~              

shmsnd.c:

  1 #include<myhead.h>
  2 #include "1.h"
  3 #define PAGE_SIZE 4096
  4 int main(int argc, const char *argv[])
  5 {
  6     //11.创建并初始化一个信号灯集
  7     int semid=open_sem(2);
  8     //1.创建key值
  9     key_t key=-1;
 10     if((key=ftok("/",'k'))==-1)
 11     {
 12         perror("ftok error");
 13         return -1;
 14     }
 15     printf("key=%d\n",key);
 16     //2.将物理内存创建出共享内存段
 17     int shmid=-1;
 18     if((shmid=shmget(key,PAGE_SIZE,IPC_CREAT|0664))==-1)
 19     {
 20         perror("shmget error");
 21         return -1;
 22     }
 23     printf("shmid=%d\n",shmid);
 24     //3.将共享内存段地址映射到用户空间
 25     //NULL表示让系统自动选择页的分段
 26     //0表示当前进程对共享内存具有读写功能
 27     char *addr=(char *)shmat(shmid,NULL,0);
 28     if(addr==(void*)-1)
 29     {
 30         perror("shmat error");
 31         return -1;
 32     }
 33     printf("addr=%p\n",addr);
 34     //4.操作共享内存
 35     //char buf[128]="";
 36     while(1)
 37     {
 38         //22.申请0号灯的资源
 39         P(semid,0);
 40         printf("请输入>>>");
 41         fgets(addr,PAGE_SIZE,stdin);//从终端输入数据
 42         addr[strlen(addr)-1]='\0';//将换行换成'\0'
 43         printf("发送成功\n");
 44         //33.释放1号灯的资源
 45         V(semid,1);
 46         if(strcmp(addr,"quit")==0)
 47             break;
 48     }
 49     //5.取消映射
 50     if(shmdt(addr)==-1)
 51     {
 52         perror("shmdt error");
 53         return -1;
 54     }
 55     //6.删除共享内存
 56     if(shmctl(shmid,IPC_RMID,NULL)==-1)
 57     {
 58         perror("shmctl error");
 59         return -1;
 60     }
 61     return 0;
 62 }                                                                                                                                                                                                       
~          

 shmrcv:

  1 #include<myhead.h>
  2 #include"1.h"
  3 #define PAGE_SIZE 4096
  4 int main(int argc, const char *argv[])
  5 {
  6     //11.创建信号灯集
  7     int semid=open_sem(2);
  8     //1.创建key值
  9     key_t key=-1;
 10     if((key=ftok("/",'k'))==-1)
 11     {
 12         perror("ftok error");
 13         return -1;
 14     }
 15     printf("key=%d\n",key);
 16     //2.将物理内存创建共享内存段
 17     int shmid=-1;
 18     if((shmid=shmget(key,PAGE_SIZE,IPC_CREAT|0664))==-1)
 19     {
 20         perror("shmget error");
 21         return -1;
 22     }
 23     printf("shmid=%d\n",shmid);
 24     //3.将共享内存段地址映射到用户空间
 25     //NULL表示让系统自动选择页分段
 26     //0表示当前进程对共享内存的读写功能
 27     char *addr=(char*)shmat(shmid,NULL,0);
 28     if(addr==(void*)-1)
 29     {
 30         perror("shmat error");
 31         return -1;
 32     }
 33     printf("addr=%p\n",addr);
 34     //4.操作共享内存
 35     //char buf[128]="";                                                                                                             
 36     while(1)
 37     {
 38         //22.申请1号灯的资源
 39         P(semid,1);
 40         printf("共享内存中的数据为:%s\n",addr);
 41         if(strcmp(addr,"quit")==0)
 42             break;
 43         //33.释放0号灯的资源
 44         V(semid,0);
 45     }
 46     //5.取消映射
 47     if(shmdt(addr)==-1)
 48     {
 49         perror("shmdt error");
 50         return -1;
 51     }
 52     //44.删除信号灯集
 53     del_sem(semid);
 54     return 0;
 55 }
~          

运行结果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1472532.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[LWC] Work with Data + Error Handling

目录 Overview Summary Use Cases for Interacting with Salesforce Data Handling Server Errors Sample Code Reference Overview Summary Use Cases for Interacting with Salesforce Data Handling Server Errors Sample Code Prerequisite: 1. Copy the ldsUtils f…

Python进阶学习:json.dumps()和json.dump()的区别

Python进阶学习&#xff1a;json.dumps()和json.dump()的区别 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程 &#x1f448; 希望得到您…

驻场人员严重划水,愈演愈烈,要请领导出面吗?

你有没有遇到过团队成员偷懒的情况&#xff1f;比如你们一起完成某个项目目标&#xff0c;干着干着你发现&#xff0c;就只有你和几个核心人员比较上心&#xff0c;很多人都在划水。 你可能会觉得这是因为大家工作态度不好&#xff0c;甚至怀疑他们的人品&#xff0c;忍不住想…

js里面有引用传递吗?

一&#xff1a;什么是引用传递 引用传递是相对于值传递的。那什么是值传递呢&#xff1f;值传递就是在传递过程中再复制一份&#xff0c;然后再赋值给变量&#xff0c;例如&#xff1a; let a 2; let b a;在这个代码中&#xff0c;let b a; 就是一个值传递&#xff0c;首先…

【Java程序设计】【C00276】基于Springboot的就业信息管理系统(有论文)

基于Springboot的就业信息管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的就业信息管理系统 本系统分为前台功能模块、管理员功能模块、学生功能模块、企业功能模块以及导师功能模块。 前台功能模块&…

勒索攻击新趋势,DarkSide解密工具

勒索攻击新趋势 2020年通过勒索病毒攻击已经成为网络犯罪分子热崇追捧的一种方式&#xff0c;全球几乎每天都有企业被勒索病毒攻击勒索&#xff0c;而且勒索的金额也越来越高&#xff0c;从几万美元到几千万美元不等&#xff0c;越来越多的黑客组织使用勒索病毒对企业发起攻击…

【python】学习笔记03-循环语句

3.1 whlie循环的基础语法 - while循环的语法格式 - while循环的注意事项 条件需提供布尔类型结果&#xff0c;True继续&#xff0c;False停止 空格缩进不能忘 请规划好循环终止条件&#xff0c;否则将无限循环 """ 演示while循环基础练习题&#xff1a;求1-10…

JSON:简介与基本使用

目录 什么是JSON&#xff1f; JSON的基本结构 JSON的基本使用 在JavaScript中使用JSON 创建JSON对象 解析JSON字符串 生成JSON字符串 在其他编程语言中使用JSON 总结 什么是JSON&#xff1f; JSON&#xff0c;全称为JavaScript Object Notation&#xff0c;是一种轻量…

matlab生成模拟的通信信号

matlab中rand函数生成均匀随机分布的随机数&#xff0c;randn生成正态分布的随机数&#xff1b; matlab来模拟一个通信信号&#xff1b; 通信信号通过信道时&#xff0c;研究时认为它会被叠加上服从正态分布的噪声&#xff1b; 先生成随机信号模拟要传输的信号&#xff0c;s…

C++基础知识(七:多态)

一、多态 常说的多态&#xff0c;是发生在类之间的多态 函数重载(静态多态/编译时多态) 类之间的多态(动态多态/运行时多态) 【1】前提 继承是多态的前提 虚函数 什么是多态&#xff1a;相同的代码&#xff0c;实现不同的功能 【2】函数重写(override) 必须有继承关系父类中必须…

python中的类与对象(2)

目录 一. 类的基本语法 二. 类属性的应用场景 三. 类与类之间的依赖关系 &#xff08;1&#xff09;依赖关系 &#xff08;2&#xff09;关联关系 &#xff08;3&#xff09;组合关系 四. 类的继承 一. 类的基本语法 先看一段最简单的代码&#xff1a; class Dog():d_…

JS防抖函数

场景 频繁触发耗时操作&#xff0c;仅关心最后一次的触发时使用防抖函数 代码 function debounce(fn , delay){let timer;return () > {clearTimeout(timer);timer setTimerout(()>{fn()},delay)} } 详解 触发一次函数&#xff0c;然后执行后续操作 function deboun…

消息中间件之RocketMQ源码分析(十七)

Broker CommitLog索引机制的数据结构 ConsumerQueue消费队列 主要用于消费拉取消息、更新消费位点等所用的索引。源代码参考org.apache.rocketmq.store.ConsumerQueue.该文件内保存了消息的物理位点、消息体大小、消息Tag的Hash值 物理位点:消息在CommitLog中的位点值消息体…

音乐格式转换软件有哪些?5款必备神器

音乐格式转换软件有哪些&#xff1f;音乐&#xff0c;作为人类情感的载体&#xff0c;伴随着我们生活的每一个角落。在享受音乐的同时&#xff0c;我们有时也面临着音乐格式不兼容的问题。不用担心&#xff0c;今天我将为大家揭秘五款音乐格式转换软件&#xff0c;让你的音乐之…

开发一套智慧工地系统需要多久时间?

什么是智慧工地&#xff1f; 智慧工地是智慧地球理念在工程领域的行业具现&#xff0c;是一种崭新的工程全生命周期管理理念。它运用信息化手段&#xff0c;通过三维设计平台对工程项目进行精确设计和施工模拟&#xff0c;围绕施工过程管理&#xff0c;建立互联协同、智能生产…

投资黄金在哪里买比较好?

黄金&#xff0c;作为一种传统的避险资产&#xff0c;历来受到投资者的青睐。在全球经济波动的大背景下&#xff0c;黄金的价值愈发凸显。那么&#xff0c;投资黄金在哪里买比较好呢&#xff1f;本文将重点探讨在香港黄金平台投资黄金的优势&#xff0c;并以金田金业为例&#…

外包工作两个月,技术退步让我决心改变

大家好&#xff0c;我是一名大专生&#xff0c;2019年通过校招进入了湖南的一家软件公司。在这里&#xff0c;我从事了接近4年的功能测试工作。然而&#xff0c;今年8月份&#xff0c;我深刻地意识到&#xff0c;我不能继续这样下去了。 长时间在一个舒适的环境里&#xff0c;…

ThreadLocal从使用到实现原理与源码详解

ThreadLocal概述 ThreadLocal是多线程中对于解决线程安全的一个操作类&#xff0c;它会为每个线程都分配一个独立的线程副本从而解决了变量并发访问冲突的问题。ThreadLocal 同时实现了线程内的资源共享。 案例&#xff1a;使用JDBC操作数据库时&#xff0c;会将每一个线程的…

Linux环境基础开发工具使用篇(三) git 与 gdb

一、版本控制器-git 1.简单理解: ①git既是服务端&#xff0c;又是客户端 ②git会记录版本的变化 ③git是一个去中心化的分布式软件 git/gitee 是基于git仓库搭建的网站&#xff0c;让版本管理可视化 2.git 三板斧提交代码 查看安装的git版本 git--version 命令行提交代…

ACM题解Day8 | 最小公倍数 GCD 模块 |最小共倍数,等差数列,后缀表达式

学习目标&#xff1a; 博主介绍: 27dCnc 专题 : 数据结构帮助小白快速入门算法 &#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d;&#x1f44d; ☆*: .&#xff61;. o(≧▽…