共享内存、网络通信

2024-08-21 21:20
文章标签 网络通信 共享内存

本文主要是介绍共享内存、网络通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、共享内存(同一主机间通信)

(1) 产生key值

  key_t ftok(const char *pathname, int proj_id);

  On  success,  the  generated key_t value is returned.  On failure -1 is returned, with errno indicating the error as  for  the  stat(2)  system call.

(2)申请对象

int shmget(key_t key, size_t size, int shmflg);

On success, a valid shared memory identifier is returned.  On error, -1 is returned, and errno is set to indicate the error.

(3)绑定

void *shmat(int shmid, const void *shmaddr, int shmflg);

On  success,  shmat() returns the address of the attached shared memory segment; on error, (void *) -1 is returned, and errno is set  to  indicate the cause of the error.

(4) 解除绑定

int shmdt(const void *shmaddr);


On  success,  shmdt()  returns 0; on error -1 is returned, and errno is set to indicate the cause of the error.

(5)销毁

 int shmctl(int shmid, int cmd, struct shmid_ds *buf);

#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <unistd.h>
#include <signal.h>
#include <string.h>void hander(int signo)
{}
int main(int argc, char *argv[])
{key_t key = ftok("/",'b');if(key == -1){perror("ftok");return 1;}//printf("key = %d\n",key);int shmid = shmget(key,1024,IPC_CREAT|0666);if(shmid == -1){perror("shmget");return 1;}//printf("id = %d\n",shmid);void *p = shmat(shmid,NULL,0);if((void *)-1 == p){perror("shmat");return 1;}signal(SIGUSR1,hander);pid_t *q = (pid_t *)p;*q = getpid();char *s = (char *)p;while(1){printf("%s\n",s);pause();if(strcmp(s,"quit") == 0)break;} if(shmdt(p) == -1){perror("shmdt");return 1;}if(shmctl(shmid,IPC_RMID,NULL) == -1){perror("shmctl");return 1;}return 0;
}
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>
#include <unistd.h>
#include <signal.h>int main(int argc, char *argv[])
{key_t key = ftok("/",'b');if(key == -1){perror("ftok");return 1;}//printf("key = %d\n",key);int shmid = shmget(key,1024,IPC_CREAT|0666);if(shmid == -1){perror("shmget");return 1;}//printf("id = %d\n",shmid);void *p = shmat(shmid,NULL,0);if((void *)-1 == p){perror("shmat");return 1;}pid_t *q = (pid_t *)p;printf("open pid = %d\n",*q);pid_t pid = *q;while(1){char *s = (char *)p;fgets(s,1024,stdin);s[strlen(s) - 1] = '\0';kill(pid,SIGUSR1);if(strcmp(s,"quit") == 0)break;}if(shmdt(p) == -1){perror("shmdt");return 1;}if(shmctl(shmid,IPC_RMID,NULL) == -1){perror("shmctl");return 1;}return 0;
}

2、网络间通信

int socket(int domain, int type, int protocol);

osi  7 层参考模型 
    1. 物理层 
       规定了物理层面的电气特性及相关机械特性 
       物理层面数据的传输 ---  一位一位二进制数据   //比特流 
    2. 数据链路层 
       规定了 传输数据的格式  //帧数据 
       //控制传输过程可靠 
    3. 网络层 (网际层)
        用于解决 网络 与 网络之间 数据传输  //数据包 
    4. 传输层 
        传输控制层,控制传输过程,保证数据完整和可靠 
    5. 会话层  
        处理一次会话过程 
    6. 表示层 
        规定了 传输数据的格式 和 方式  //加密 
    7. 应用层 
        就是直接获取要收发的数据     

tcp/ip 五层模型 

应用层 
    传输层 
    网络层 
    数据链路层 
    物理层 
    
4层模型 
    应用层 
    传输层 
    网络层 
    网络接口层 

这篇关于共享内存、网络通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

【Linux】Linux 共享内存:高效的进程间通信

文章目录 Linux 共享内存:高效的进程间通信1. 什么是共享内存?2. 共享内存的实现步骤2.1 创建共享内存2.2 映射共享内存2.3 读写共享内存2.4 解除映射和删除共享内存 3. 共享内存的同步问题信号量示例: 4. 共享内存的优势与劣势优势:劣势: 5. 使用场景6. 结论 Linux 共享内存:高效的进程间通信 共享内存(Shared Memory)是 Li

应用层简单实现udp / tcp网络通信

一、常见网络接口总结 1、创建 socket 文件描述符 (TCP/UDP, 客户端 + 服务器) int socket(int domain, int type, int protocol); domain:AF_INET:网络通信,AF_LOCAL:本地通信 type:UDP:SOCK_DGRAM,TCP:SOCK_STREAM protocol:协议编号一开始设0 返回值:文件描

“掌握Linux网络编程艺术,构建跨平台的网络通信解决方案!“#Linux系统编程之网络编程

"掌握Linux网络编程艺术,构建跨平台的网络通信解决方案!"#Linux系统编程之网络 前言预备知识一、 网络编程概述1.1 网络编程概述图1.2 TCP/UDP对比(面试)1.3 端口号的作用 二、 字节序2.1 大端字节序(Big-Endian)2.2 小端字节序(Little-Endian)2.3 字节序的重要性2.4 字节序转换函数2.5 字节序示意图 三、 socket编程步骤四

TCP网络通信服务器端简单示例

服务器端: #include <stdio.h> #include <winsock2.h> //和网络通信相关的函数的声明,类型的声明,常量的定义等都在此头文件中 #pragma comment(lib,"ws2_32.lib") int main() { //第一步:初始化Socket函数库 WSADATA wsaData; //向系统请求使用2.2版本的Socket函数库,wsaDat

udp网络通信 socket

套接字是实现进程间通信的编程。IP可以标定主机在全网的唯一性,端口可以标定进程在主机的唯一性,那么socket通过IP+端口号就可以让两个在全网唯一标定的进程进行通信。 套接字有三种: 域间套接字:实现主机内部的进程通信的编程 原始套接字:使用网络层或者数据链路层的接口进行编程,更难更底层,例如制作抓包等网络工具 网络套接字:实现用户通信的编程 udp网络通信 服务端server 分

c++ linux——进程共享内存

共享内存概念: 每个进程的虚拟内存对应一块物理地址,如果两个进程需要共享某一块内存,则各自的虚拟内存会有一小块映射到同一片物理地址上。是最高效的进程间通信方式。 关键就是四个函数 shmget(创建或者获取现有的共享内存标识符) shmat (将共享内存挂接到当前进程) shmdt(共享内存与当前进程取消挂接) shctrl(删除共享内存或者改变权限) 举例实现: 进程1 #include<sy

JAVA—网络通信

本文是学习网络通信入门和简单了解UDP协议和TCP协议,学习和了解CS架构和简单了解BS架构和HTTP协议(部分图片来自黑马程序员) 目录 1.网络通信三要素 (1)IP地址 (2)端口号 (3)协议 2.UDP通信—快速入门 3.UDP通信—多发多收 4.TCP通信—快速入门 5.TCP通信—多发多收 6.TCP通信—同时接收多个客户端 7.TCP通信—综合

进程间通信方式(共享内存、信号灯集、消息队列)

共享内存 特点 1)共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存,而不需要任何数据的拷贝。 2)为了在多个进程间交换信息,内核专门留出了一块内存区,可以由需要访问的进程 将其映射到自己的私有地址空间。进程就可以直接读写这一内存区而不需要进行数据的拷贝,从而大大提高的效率。 3) 由于多个进程共享一段内存,因此也需要依靠某种同步机制,如互斥锁和信号量等 使

Android 网络通信(Asynctask类的使用)

现在大部分app需要联网,所以作为开发人员就必然要了解网络通信这方面的知识。 首先要知道的一点是网络通信是耗时操作,为了不让这些耗时的任务影响界面响应,就应当使用异步任务进行处理。java是用thread,例如 new Thread(){ run(){ } }.start(); 在run()中进行网络通信处理。但Android有个重要机制,ui主线程安全机制,也就是说任何改变ui的操作