嵌入式操作系统网络编程(7)

2024-02-17 17:18

本文主要是介绍嵌入式操作系统网络编程(7),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

D3.31

进程间通信-IPC
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

删除:rm -f /tmp/test

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

一边写,一边读

Write:

Read:

共享内存:

共享内存的特点:

1、减少进入内核空间的次数

2、直接使用地址来读写缓存时,效率会更高,适用于大数据量的通信

D4.1

队列消息API

、作用:当多个进程/线程进行共享操作时,用于资源保护(互斥+同步操作),以防止出现相互干扰的情况,解决方法为加锁。

 注:互斥:该进程在操作时其他进程不能操作,不关心操作的顺序问题;

同步:多个共享操作时,进程必须要有统一操作的步调,按照一定的顺序来操作。

2、信号量的使用步骤:

(1)进程调用semget函数创建新的信号量集合,或者获取已有的信号量集合;(2)调用semctl函数给集合中的每个信号量设置初始值;(3)调用semop函数,对集合中的信号量进行p、v操作(加锁解锁);

p操作(加锁):对信号量的值进行-1,如果信号量的值为0,p操作就会阻塞。

v操作(解锁):对信号量的值进行+1,v操作不存在阻塞的问题。

(4)调用semctl删除信号量集合。

3、分类:二值信号量、多值信号量。

1、semget(创建/获取信号量)

注:实现互斥时:集合中只需要一个信号量;实现同步时:集合中需要多个信号量。

1、 头文件:#include
<sys/types.h> #include
<sys/ipc.h> #include <sys/sem.h>

2、 函数原型:int semget(key_t key, int nsems, int semflg);

3、 函数形参:key:用于为信号量生成唯一的信号量semid(标识符);

nsems:指定集合中信号量的个数;

semflg:指定创建时的原始权限,一般都设置为0664|IPC_CREAT。

4、 函数返回值:成功返回信号量集合的标识符,失败返回-1,错误存于erron中。

2、semctl(控制信号量)

1、 头文件:#include
<sys/types.h> #include
<sys/ipc.h> #include <sys/sem.h>

2、 函数原型:int semctl(int semid, int semnum, int cmd, …);

注:...表示它是一个变参函数,如果第四个参数用不到的话,可以省略不写。

3、 函数形参:semid:信号量集合的标识符;

semnum:信号量集合中某个信号量的编号;

cmd:控制选项。

注:cmd选项: (常用选项:IPC_RMID、SETVAL)

① IPC_STAT:从内核将信号量的属性信息读到第四个参数所指定的struct semid缓存中。

      ② IPC_SET:修改属性信息,此时也会用到struct semid结构体变量。注:struct semid结构体与共享内存、消息队列中的结构体均相似。③ IPC_RMID:删除信号量,删除操作时第四个参数用不到省略不写。示例:semctl(semid, 0,

IPC_RMID);

         注:当集合中所有的信号量都被删除后,信号量集合也就被删除了。④ SETVAL:通过第四个参数,给集合中semnum编号的信号量设置int初始值。注:SETVAL属于进程信号量所独有的选项。

4、 函数返回值:成功返回非-1值,失败返回-1,错误存于erron中。

3、semop(操作信号量)

1、 头文件:#include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h>

2、 函数原型:int semop(int semid,
struct sembuf *sops, unsigned nsops);

3、 函数形参:semid:信号量集合的标识符;

sops:struct sembuf *型的结构体名称;

nsop:指定结构体数组sops的元素个数。

注:(1)每一个数组成员对应一个信号量,每一个元素都是一个struct
sembuf结构体变量,内部成员的决定:①对集合中指定信号量进行操作;②要进行p操作还是v操作。

(2)struct sembuf结构体成员为:sem_num、sem_op、

sem_flg,且该结构体semop的头文件中已经定义,无需自己定义。

(3)sem_num:信号量编号,决定对集合中哪一个信号量进行p、v操作。(4)sem_op:设置为-1,表示进行p操作,设置为1,表示进行v操作。(5)sem_flg:① IPC_NOWAIT:当信号量的值为0时p操作不阻塞(非必要不使用)。

② SEM_UNDO:防止死锁。

注:SEM_UNDO,若进程结束时未进行v操作,OS则自动进行v操作。

4、 函数返回值:成功返回信号量集合的标识符,失败返回-1,错误存于erron中。

5、使用示例:(使用时可用如下”sem[].xxxx”,或者”xxxx={}”)

struct sembuf sem[1];

sem[0].sem_num =
0;

sem[0].sem_op =
-1;

sem[0].sem_flg =
SEM_UNDO;

//struct sembuf
sem[0]={0,-1, SEM_UNDO };

semop(semid,sem,1);
//p操作

sem[0].sem_op =
1;

semop(semid,sem,1);//v操作

这篇关于嵌入式操作系统网络编程(7)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/718473

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

AOP编程的基本概念与idea编辑器的配合体验过程

《AOP编程的基本概念与idea编辑器的配合体验过程》文章简要介绍了AOP基础概念,包括Before/Around通知、PointCut切入点、Advice通知体、JoinPoint连接点等,说明它们... 目录BeforeAroundAdvise — 通知PointCut — 切入点Acpect — 切面

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁