IPC进程间通信方式及网络通信

news2025/1/11 5:40:14

一、IPC进程间通信方式

1.共享内存(最高效的进程间通信方式)

        其允许两个或多个进程共享一个给定的存储区,这一段存储区可以被两个或以上的进程映射至自己的地址空间中,一个进程写入共享内存的信息,可以被其他使用这个共享内存的进程读取。

        

                        1.是一块内核预留的空间

                        2.避免了用户空间到内核空间的数据拷贝

2. 步骤1:产实key 值:key_t   ftok(const char *pathname,int   proj  id)

        参数:pathname:文件路径   参数id:整形变量,子序号,参与构成ftok()函数的返回值

        过程中使用文件属性中的st_dev与st_ino.

        组成:第31-24位为ftok()第二个参数的低8位,23-16位为st_dev的低8位,15-0为st-ino的低16位

        步骤2:创建一个共享内存区:int  shmget(key_t  key, size_t size,int   shmflg)

        参数:key值,共享区域长度,标志位/权限(包含IPC_CREAT与IPC_EXCL(存在则出错))

        成功返回一个shmid号,失败返回-1

      步骤3:绑定地址空间:void  *shmat(int shmid,const  void *shmaddr,int  shmflg)

        参数:要映射的本地内存,本地可用的地址(不确定为NULL,系统分配)

                   shmflg为0表示读写,SHM_RDONLY 表示只读

        成功返回映射地址,一般为shmaddr     失败(void *)-1

        步骤4:撤销映射:int  shmdt(const   void * shmaddr);

        参数:要断开的映射地址

        成功返回0      失败返回-1

        步骤5:删除ipc对象int   shmctl(int   shmid,int  cmd,struct  shmid_ds  *buf);        

        参数:cmd是向共享内存发出的命令

        IPC_STT:获取内存段的shmid_ds结构,并把它存储在buf参数所指定的地址中。

        IPC_SET 设置内存段shmid_ds结构的ipc_perm成员的值,此命令是从buf参数中获得该值的。

        IPC_RMID:标记某内存段,以备删除。该命令并不真正地把内存段从内存中删除。相反,它只是标记上该内存段,以备将来删除。只有当前连接到该内存段的最后一个进程正确地断开了与它的连接,实际的删除操作才会发生。当然,如果当前没有进程与该内存段相连接,则删除将立刻发生。为了正确地断开与其共享内存段的连接,进程需要调用 shmdt()函数。

        buf  NULL 表示只删除对象。

        成功 0            失败 -1

二、网络通信

1.

 

应用层:应用层是TCP/IP模型的最顶层,包含了各种网络应用程序,它主要关注的是传输过来的数据要干啥用。其中一种广泛使用的应用层协议 HTTP、HTTPS。

传输层:负责两台主机之间的数据传输,不考虑中间路径,只关心起点和终点,能够确保数据可靠的从源主机发送到目标主机。比较常见的传输层协议有 TCP、UDP。

网络层:负责地址管理和路由选择,进行两个遥远网络结点之间路径规划。例如在网络层 IP 协议中,通过IP地址来标识一台主机,并通过路由表的方式规划出两台主机之间的数据传输的线路(路由)。

数据链路层:负责设备之间的数据帧的传送和识别,主要关注两个相邻结点之间的传输。例如通过物理地址(如MAC地址)在相邻节点之间传输。数据链路层最典型的协议 以太网协议。

物理层:负责光/电信号的传递方式,通常指网络通信的基础设施。网线、光纤、网络接口等。

2.ip地址:网络中主机的唯一标识,它由网络地址和主机号组成。网络地址是子网的唯一标识,类似于电话号码的区号;主机号是子网内每台主机的编号。在现在(IPv4)的网络中,IP地址是32bit的二进制数,采用大端字节序

        表示方法为点分十进制

类型范围用途
A类0.x.x.x-127.x.x.x10.x.x.x私网(局域网)地址
127.x.x.x环回网络地址
其他大型主干网地址
B类128.x.x.x-191.x.x.x172.16.x.x - 172.31.x.x
169.254.x.x
其他
C类192.x.x.x-223.x.x.x192.168.x.x
D类组播地址
E类保留

2.端口号:通过IP地址  定位到 一台 具体的主机上,通过端口号定位主机上的具体某一个进程

        unsigned short类型,范围是0~65535,其中 0 ~ 1024之间的端口号被系统占用

        ip+端口即为

进程在网络的 地址 

3.UDP(广播):UDP(User Datagram Protocol)用户数据报协议,是不可靠的无连接的协议。

                                在数据发送前,因为不需要进行连接,所以可以进行高效率的数据传输。

               1. 发送小尺寸数据(如对DNS服务器进行IP地址查询时)
               2. 在接收到数据,给出应答较困难的网络中使用UDP。(如:无线网络)
               3. 适合于广播/组播式通信中。
               4. MSN/QQ/Skype等即时通讯软件的点对点文本通讯以及音视频通讯通常采用UDP协议
               5. 流媒体、VOD、VoIP、IPTV等网络多媒体服务中通常采用UDP方式进行实时数据传输

        特点:不可靠、无连接、数据报

4.TCP:是一种面向连接的传输层协议,它能提供高可靠性通信(即数据无误、数据无丢失、数据无失序、数据无重复到达的通信) 

                1. 适合于对传输质量要求较高,以及传输大量数据的通信。
                2. 在需要可靠数据传输的场合,通常使用TCP协议
                3. QQ等即时通讯软件的用户登录账户管理相关的功能通常采用TCP协议

        特点: 面向连接、可靠传输、面向字节流程

三、基于UDP网络编程:C/S

1.socket:int socket(int  domain,int  type,int  protocol)创建一个用来通信的终端节点并返回文件描述

        参数: domain:支持的协议族
                    IPV4协议族 -> AF_INET
                    type: 套接字的类型
                    SOCK_STREAM:  流式套接字  TCP
                    SOCK_DGRAM:      数据报套接字 UDP
                    SOCK_RAW:      原始套接字
                    protocol:默认为0

        成功返回建立用来通信的新文件描述符          失败返回-1

2.sendto:ssize_t   sendto(int  sockfd,const  char *buf,size_t  len,int flags,const  sturuct  sockaddr *dest_addr,socklen_t   addrlen);给另一个套接字发送数据

        参数:
                     sockfd:套接字文件描述符
                     buf: 要发送数据存放空间首地址
                     len:要发送数据的长度
                     flags:发送的属性,默认为0
                     dest_addr:目的地址
                     addrlen:addr的长度

                成功返回实际发送的字节个数      失败返回-1 

3. uint16_t htons(uint16_t hostshort); 将本地字节序转化为网络字节序
        参数: hostshort:本地端口号
            返回网络字节序端口号
4. in_addr_t inet_addr(const char *cp)将字符串IP地址转换为二进制IP地址
    参数: cp:字符串IP地址空间首地址
            成功返回二进制IP地址

     
    

 

 

 

 

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

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

相关文章

SQL Server数据库查询常用语句汇总

这里,汇总了在使用SQL Server数据库的过程中经常会写的查询语句。 情形1 根据时间查询最新一条数据 (dtime类型为datetime) select top 1 名称 as name,列名1 as parname1,列名2 as parname2,dtime,col1,col2 from demo order by dtime …

算法基础及例题

1、双指针 维护区间信息、子序列匹配、利用序列有序性、单项链表找环双指针 - OI Wiki (oi-wiki.org) 盛最多水的容器https://leetcode.cn/problems/container-with-most-water/ public class Solution {public int maxArea(int[] height) {int l 0, r height.length - 1;int…

docker 导出导入镜像

这两天我在自己的虚拟机器上想docker pull tomcat 但是一直失败,那么我想到了一个思路就是在阿里云上的服务器上把镜像打包,然后倒导入的本地的虚拟机上。 查看当前的镜像: 我们现在想要打包哪个镜像呢,比如打包:tom…

线段树-点修区查

翻博客的时候突然发现线段树好像一个没有,我就准备把线段树给讲一下 分三个章节 点修区查 区修区查 区修区查(带乘法) 今天这一章比较简单,最多就区查稍微要动一点脑子 题目简介 输入n和m,n代表数的个数&#x…

python多进程multiprocessing(共享字典)

一,线程与进程的区别 纲领:进程是资源分配的最小单位,线程是CPU调度的最小单位 听老师傅说,在python上线程作用不大,最好还是使用多进程。 二,简单使用multiprocessing 检测一下电脑性能如何&#xff1a…

Mac电脑遇到DNS解析失败,ip可以访问,域名无法访问

当Mac电脑遇到DNS解析失败的问题时,可以尝试以下几个解决方法‌: 1.检查网络连接‌:确保Mac已连接到可用的网络,并且网络连接正常。可以尝试重新连接Wi-Fi或使用有线连接来排除网络问题。 2.清除DNS缓存‌:打开终端应…

技术革新,智能恢复:2024年AI驱动的数据恢复软件

数据的脆弱性不容忽视,误删、格式化、硬盘损坏等意外情况时有发生,让我们面临数据丢失的风险。幸运的是现在有不少数据恢复精灵应运而生。今天,就让我们一起探索2024年大家都在用的数据恢复精灵工具。 1.福昕数据恢复 链接直达:…

项目控件组(基于项)Item-Based-Qt-思维导图-学习笔记

项目控件组(基于项)Item-Based 控件组 (1)List Widget:清单控件 QListWidget 控件简介 继承关系:继承自 QListView 功能:提供一个基于项的列表小部件,允许添加和删除项目,使用内部…

springboot的启动流程原理

目录 一:入口简介: 二。创建SpringApplication对象 1.推倒出当前项目的启动类型 2.设置Initializer初始化器 3.初始化Listerner监听器 4.反推出main方法所在的class对象。 三.运行SpringApplication#run(java.lang.String...)方法 1):获取运行监听器: 2)发布启动过程中…

IPC进程通信以及网络通信

一、IPC 进程间通信方式 共享内存 //最高效的进程间通信方式 不需要把用户的东西再复制到内核 他们与内核进行绑定 共享内存: 1、是一块,内核预留的空间 2、最高效的通信方式 //避免了用户空间到内核空间的数据拷贝 IPC通信方式 ---操作流程类似的…

“决胜面试:高频题目与算法策略一览”

干货分享,感谢您的阅读! (暂存篇---后续会删除,完整版和持续更新见高频面试题基本总结回顾(含笔试高频算法整理)) 备注:引用请标注出处,同时存在的问题请在相关博客留言…

wps题注为表格或图片编号

word中为表格添加题注: 问题:多次或多人编辑导致--序号不能联动更新(域代码不一致,如图) 所以是否可以批量替换word里的域代码?如果可以这问题就解决了————失败 解决办法: 如图,复制表头&…

[数据集][目标检测]工程机械车辆检测数据集VOC+YOLO格式3189张10类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):3189 标注数量(xml文件个数):3189 标注数量(txt文件个数):3189 标注…

万户 ezOFFICE receivefile_gd.jsp SQL注入漏洞复现

0x01 产品简介 万户OA ezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品,统一的基础管理平台,实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台,将外网信息维护、客户服务、互动交流和日…

Thymeleaf+Bootstrap封装分页组件

效果 代码 templates/components/pagination.html <!doctype html> <html lang"zh-CN" xmlns:th"http://www.thymeleaf.org"> <body> <div class"d-flex justify-content-between align-items-center mb-3" th:fragment&…

Neo4j 图数据库入门

图形数据库存储节点和关系&#xff0c;而不是表或文档。数据的存储方式就像你在白板上勾画想法一样。您的数据存储不受预定义模型的限制&#xff0c;允许以非常灵活的方式考虑和使用它。 一、核心概念&#xff1a;属性图形模型 Neo4j使用属性图数据库模型。图数据结构由节点(离…

React错误:无法在‘node’上执行‘insertBefore‘:要在其前插入新节点的节点不是此节点的子节点

我在NextJS中用cloudinary实现了一个上传图片的页面&#xff0c;结果图片上传之后页面就无法点击操作&#xff0c;并在控制台报错&#xff1a; Failed to execute insertBefore on Node: The node before which the new node is to be inserted is not a child of this node. …

在 Arch Linux 上安装 Linux、Apache、MySQL、PHP(LAMP)堆栈的方法

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 关于 LAMP LAMP 栈是一组用于启动和运行 Web 服务器的开源软件。该首字母缩略词代表 Linux、Apache、MySQL 和 PHP。Arch Linux 使用强…

【HTML】为网页添加列表和超链接

1、列表 1.1、无序列表 <ul><li>列表项1</li><li>列表项2</li><li>列表项3</li> ...... </ul>无序列表的常用type属性值 1.2、有序列表 <ol><li>列表项1</li><li>列表项2</li><li>列…

【乐吾乐大屏可视化组态编辑器】下载离线部署包

下载离线部署包/组件包 在线使用&#xff1a;https://v.le5le.com/ 导出为Zip文件 Zip包主要用于大屏可视化平台快捷导入导出项目。 如图下图所示&#xff0c;Zip包仅包含数据文件和图片文件&#xff0c;不包含js等依赖库。需要有一定开发能力者参考官方文档补充依赖库才能…