嵌入式操作系统网络编程(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

相关文章

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

C#反射编程之GetConstructor()方法解读

《C#反射编程之GetConstructor()方法解读》C#中Type类的GetConstructor()方法用于获取指定类型的构造函数,该方法有多个重载版本,可以根据不同的参数获取不同特性的构造函... 目录C# GetConstructor()方法有4个重载以GetConstructor(Type[]

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~