当前位置: 首页 > news >正文

【Linux学习笔记】进程通信之消息队列和信号量

【Linux学习笔记】进程通信之消息队列和信号量

🔥个人主页大白的编程日记

🔥专栏Linux学习笔记


文章目录

  • 【Linux学习笔记】进程通信之消息队列和信号量
    • 前言
    • 一. system V消息队列
    • 二. system V信号量
      • 2.1 并发编程,概念铺垫
      • 2.2 信号量
      • 2.3 内核是如何组织管理IPC资源的
      • 2.4 在minishell中添加管道的实现
    • 后言

前言

哈喽,各位小伙伴大家好!上期我们讲了进程间通信之共享内存
今天我们讲的是进程通信之消息队列和信号量。话不多说,我们进入正题!向大厂冲锋!
在这里插入图片描述

一. system V消息队列

  • 消息队列提供了一个从一个进程向另外一个进程发送一块数据的方法
  • 每个数据块都被认为是有一个类型,接收者进程接收的数据块可以有不同的类型值
  • 特性方面
    • IPC资源必须删除,否则不会自动清除,除非重启,所以system V IPC资源的生命周期随内核

在这里插入图片描述

二. system V信号量

信号量主要用于同步和互斥的,下面先来看看什么是同步和互斥。

2.1 并发编程,概念铺垫

在这里插入图片描述

在这里插入图片描述

  • 多个执行流(进程), 能看到的同一份公共资源:共享资源
  • 被保护起来的资源叫做临界资源
  • 保护的方式常见:互斥与同步
  • 任何时刻,只允许一个执行流访问资源,叫做互斥
  • 多个执行流,访问临界资源的时候,具有一定的顺序性,叫做同步
  • 系统中某些资源一次只允许一个进程使用,称这样的资源为临界资源或互斥资源。
  • 在进程中涉及到互斥资源的程序段叫临界区。你写的代码=访问临界资源的代码(临界区)+不访问临界资源的代码(非临界区)
  • 所谓的对共享资源进行保护,本质是对访问共享资源的代码进行保护
    在这里插入图片描述

2.2 信号量

特性方面

  • IPC资源必须删除,否则不会自动清除,除非重启,所以system V IPC资源的生命周期随内核

理解方面

  • 信号量是一个计数器

作用方面

  • 保护临界区

本质方面

  • 信号量本质是对资源的预订机制

操作方面

  • 申请资源,计数器–,P操作
  • 释放资源,计数器++,V操作

电影院的例子

2.3 内核是如何组织管理IPC资源的

在这里插入图片描述

2.4 在minishell中添加管道的实现

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <fcntl.h>#define MAX_CMD 1024
char command[MAX_CMD];
int do_face()
{memset(command, 0x00, MAX_CMD);printf("minishell$ ");fflush(stdout);if (scanf("%s", command) == 0) {getchar();return -1;}return 0;
}char **do_parse(char *buff)
{int arg = 0;static char *argv[32];char *ptr = buff;while(*ptr != '\0') {if (!isspace(*ptr)) {argv[arg++] = ptr;while((!isspace(*ptr)) && (*ptr) != '\0') {ptr++;}continue;}*ptr = '\0';ptr++;}argv[arg] = NULL;return argv;
}int do_redirect(char *buff)
{char *ptr = buff, *file = NULL;int type = 0, fd, redirect_type = -1;while(*ptr != '\0') {if (*ptr == '>') {*ptr++ = '\0';redirect_type++;if (*ptr == '>') {*ptr++ = '\0';redirect_type++;}}while(isspace(*ptr)) {ptr++;}}file = ptr;while((!isspace(*ptr)) && *ptr != '\0') {ptr++;}*ptr = '\0';if (redirect_type == 0) {fd = open(file, O_CREAT|O_TRUNC|O_WRONLY, 0664);} else {fd = open(file, O_CREAT|O_APPEND|O_WRONLY, 0664);}dup2(fd, 1);
}int do_command(char *buff)
{int pipe_num = 0, i;char *ptr = buff;int pipefd[32][2] = {{-1}};int pid = -1;pipe_command[pipe_num] = ptr;while(*ptr != '\0') {if (*ptr == '|') {pipe_num++;*ptr++ = '\0';pipe_command[pipe_num] = ptr;continue;}ptr++;}pipe_command[pipe_num + 1] = NULL;return pipe_num;
}int do_pipe(int pipe_num)
{int pid = 0, i;int pipefd[10][2] = {{-1}};char *argv = {NULL};for (i = 0; i <= pipe_num; i++) {pipe(pipefd[i]);}for (i = 0; i <= pipe_num; i++) {pid = fork();if (pid == 0) {do_redirect(pipe_command[i]);argv = do_parse(pipe_command[i]);close(pipefd[i][1]);dup2(pipefd[i][0], 0);if (i != pipe_num) {close(pipefd[i + 1][0]);dup2(pipefd[i + 1][1], 1);}execvp(argv[0], argv);} else {close(pipefd[i][0]);close(pipefd[i][1]);waitpid(pid, NULL, 0);}}return 0;
}int main(int argc, char *argv[])
{int num = 0;while(1) {if (do_face() < 0)continue;num = do_command(command);do_pipe(num);}return 0;
}

后言

这就是进程通信之消息队列和信号量。大家自己好好消化!今天就分享到这! 感谢各位的耐心垂阅!咱们下期见!拜拜~

相关文章:

  • 大城网站建设黄页推广2021
  • 国内最大的网站制作公司如何优化网络连接
  • 合肥哪个公司做网站好防城港网站seo
  • 网站营销的流程沧州做网络推广的平台
  • 网站推广seo设置seo的中文含义
  • wordpress更新慢优化大师官方免费
  • Oracle数据库捕获造成死锁的SQL语句
  • 采集文章+原创AI处理+发布网站详细教程
  • 开疆智能CCLinkIE转ModbusTCP网关连接PCA3200电能表配置案例
  • HarmonyOS NEXT仓颉开发语言实战案例:银行App
  • 【C++】组合模式
  • GitLab 18.1 发布依赖列表过滤、合规状态报告控制状态弹窗,可升级体验!
  • 前端框架大乱斗:React、Vue 和 Angular 的相爱相杀
  • 连接打印机0x0000011b错误两种完美解决方法
  • LightGBM:极速梯度提升机——结构化数据建模的终极武器
  • 数据结构进阶 第六章 树与二叉树
  • MongoDB 相关知识文档
  • YOLOv13:目标检测的全面攻略与实战指南
  • 进程和线程的区别?
  • 组织策略性陪伴顾问
  • 认识Jacobian
  • Java 大视界 -- Java 大数据机器学习模型在卫星通信信号干扰检测与智能抗干扰中的应用(323)
  • 【机器学习第一期(Python)】梯度提升决策树 GBDT
  • 2D写实交互数字人如何重塑服务体验?
  • 4.2_1朴素模式匹配算法
  • DevSecOps时代下测试工具的全新范式:从孤立到融合的质变之路