共享内存 windows和linux

服务端,即写入端


#include <iostream>
#include <string.h>
#define BUF_SIZE 1024
#ifdef _WIN32
#include <windows.h>
#define SHARENAME L"shareMemory"
HANDLE g_MapFIle;
LPVOID g_baseBuffer;
#else
#define SHARENAME "shareMemory"
#include <sys/shm.h>
#include <sys/time.h>
#include <unistd.h>
int g_shmid = -1;
char* g_baseBuffer = NULL;
#endifvoid CloseShareMemory()
{
#ifdef _WIN32if (g_baseBuffer) {FlushViewOfFile(g_baseBuffer, BUF_SIZE);UnmapViewOfFile(g_baseBuffer);g_baseBuffer = NULL;}if (g_MapFIle) {CloseHandle(g_MapFIle);g_MapFIle = NULL;}
#elseshmdt(g_baseBuffer);shmctl(g_shmid, IPC_RMID, 0);//删除
#endif
}bool CreateShareMemory()
{
#ifdef _WIN32if (g_MapFIle)CloseShareMemory();g_MapFIle = CreateFileMapping(INVALID_HANDLE_VALUE,	//物理文件句柄NULL,					//默认安全级别PAGE_READWRITE,			//可读可写0,						//高位文件大小BUF_SIZE,				//地位文件大小SHARENAME				//共享内存名称);if (g_MapFIle) {//映射缓存区视图,得到指向共享内存指针g_baseBuffer = MapViewOfFile(g_MapFIle,				//共享内存句柄FILE_MAP_ALL_ACCESS,	//可读可写许可0,0,BUF_SIZE);memset(g_baseBuffer, 0, BUF_SIZE);//初始化 置 0 return true;}
#elsekey_t key = ftok(SHARENAME, 0);g_shmid = shmget(key, BUF_SIZE, IPC_CREAT | 0666);if (g_shmid != -1) {g_baseBuffer = (char*)shmat(g_shmid, 0, 0);return true;}
#endifreturn false;
}int main()
{//创建if (!CreateShareMemory()) {std::cout << "CreateShareMemory error!\n";return -1;}//写入数据char ch[1024];while (1) {std::cout << "写入数据或输入exit退出:" << std::endl;std::cin >> ch;if (0 == strcmp(ch, "exit"))break;memcpy(g_baseBuffer, ch, 1024);}//断开 关闭CloseShareMemory();return 0;
}

客户端,即读取端


#include <iostream>
#include <string.h>
#define BUF_SIZE 1024
#ifdef _WIN32
#include <windows.h>
#define SHARENAME L"shareMemory"
HANDLE g_MapFIle;
LPVOID g_baseBuffer;
#else
#define SHARENAME "shareMemory"
#include <sys/shm.h>
#include <sys/time.h>
#include <unistd.h>
int g_shmid = -1;
char* g_baseBuffer = NULL;
#endifvoid CloseShareMemory()
{
#ifdef _WIN32if (g_baseBuffer) {FlushViewOfFile(g_baseBuffer, BUF_SIZE);UnmapViewOfFile(g_baseBuffer);g_baseBuffer = NULL;}if (g_MapFIle) {CloseHandle(g_MapFIle);g_MapFIle = NULL;}
#elseshmdt(g_baseBuffer);//shmctl(g_shmid, IPC_RMID, 0);//删除
#endif
}bool OpenShareMemory()
{
#ifdef _WIN32if (g_baseBuffer)CloseShareMemory();g_MapFIle = OpenFileMapping(FILE_MAP_ALL_ACCESS, 0, SHARENAME);if (g_MapFIle) {g_baseBuffer = MapViewOfFile(g_MapFIle, FILE_MAP_ALL_ACCESS, 0, 0, BUF_SIZE);return true;}
#elsekey_t key = ftok(SHARENAME, 0);g_shmid = shmget(key, BUF_SIZE, IPC_CREAT | 0666);if (g_shmid != -1) {g_baseBuffer = (char*)shmat(g_shmid, 0, 0);return true;}
#endifreturn false;
}int main()
{while (1) {//打开if (!OpenShareMemory()) {std::cout << "CreateShareMemory error!\n";return -1;}//读取char str[1024];memcpy(str, g_baseBuffer, 1024);memset(g_baseBuffer, 0, BUF_SIZE);if(str[0] != '\0')std::cout << "read  value:" << str << std::endl;//断开 关闭CloseShareMemory();
#ifdef _WIN32Sleep(100);
#else#endif}return 0;
}

windows演示图
在这里插入图片描述
linux 演示图
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端需要理解的数据治理与异常监控知识

1 数据治理 前端数据治理的重要指标是准确性和数据&#xff0c;一个数据对象包括数据值和其他元数据。 2 数据上报方式 2.1 Image 通过将采集的数据拼接在图片请求的后面&#xff0c;向服务端请求一个 1*1 px 大小的图片&#xff08;gif&#xff09;实现的&#xff0c;设置…

day01_Java概述丶环境搭建

Java背景知识 Java概述 概述&#xff1a;计算机语言就是人与计算机之间进行信息交流沟通的一种特殊语言。所谓计算机编程语言&#xff0c;就是人们可以使用编程语言对计算机下达命令&#xff0c;让计算机完成人们需要的功能。 Java语言&#xff1a;是美国Sun公司&#xff08…

并发-并发挑战及底层实现原理笔记

并发编程挑战 上下文切换 cpu通过给每个线程分配cpu时间片实现多线程执行&#xff0c;时间片是cpu分配给各个线程的时间&#xff0c;cpu通过不断切换线程执行。线程有创建和上下文切换的开销。减少上下文切换的方方法 – 无锁并发编程&#xff0c;eg&#xff1a;将数据的id按…

ubuntu学习(四)----文件写入操作编程

1、write函数的详解 ssize_t write(int fd,const void*buf,size_t count); 参数说明&#xff1a; fd:是文件描述符&#xff08;write所对应的是写&#xff0c;即就是1&#xff09; buf:通常是一个字符串&#xff0c;需要写入的字符串 count&#xff1a;是每次写入的字节数…

Linux线程 --- 生产者消费者模型(C语言)

在学习完线程相关的概念之后&#xff0c;本节来认识一下Linux多线程相关的一个重要模型----“ 生产者消费者模型” 本文参考&#xff1a; Linux多线程生产者与消费者_红娃子的博客-CSDN博客 Linux多线程——生产者消费者模型_linux多线程生产者与消费者_两片空白的博客-CSDN博客…

pytestx重新定义接口框架设计

概览 脚手架&#xff1a; 目录&#xff1a; 用例代码&#xff1a; """ 测试登录到下单流程&#xff0c;需要先启动后端服务 """test_data {"查询SKU": {"skuName": "电子书"},"添加购物车": {"sk…

一篇文章带你彻底了解Java常用的设计模式

文章目录 前言1. 工厂模式使用示例代码优势 2. 单例模式说明使用示例代码优势 3. 原型模式使用示例代码优势 4. 适配器模式使用示例代码优势 5. 观察者模式使用示例代码优势 6. 策略模式使用示例代码优势 7. 装饰者模式使用示例代码优势 8. 模板方法模式使用示例代码优势 总结 …

网络学生用品商店系统设计与实现(论文+源码)_kaic

摘 要 随着互联网的发展&#xff0c;人们的生活发生了巨大的变化&#xff0c;给人们的生活、工作等方面带来了相当大的提高&#xff0c;电子化成为了节约成本、调高效率的代名词。电子商务是利用微电脑技术和网络通讯技术进行的商务活动&#xff0c;买卖双方通过网络所进行各…

Windows商店引入SUSE Linux Enterprise Server和openSUSE Leap

在上个月的Build 2017开发者大会上&#xff0c;微软宣布将SUSE&#xff0c;Ubuntu和Fedora引入Windows 商店&#xff0c;反应出微软对开放源码社区的更多承诺。 该公司去年以铂金会员身份加入Linux基金会。现在&#xff0c;微软针对内测者的Windows商店已经开始提供 部分Linux发…

_数字矩阵

题目&#xff1a;一个3阶的数字矩阵如下&#xff1a; 1 2 3 8 9 4 7 6 5 现在给定数字n(1<n≤20)&#xff0c;输出n阶数字矩阵。 思路&#xff1a; 放出一条好玩的贪吃蛇&#xff0c;按照右下左上的顺序吃蛋糕&#xff0c;一边吃蛋糕&#xff0c;一边拉数字&#xff1b…

提升团队效率!探索多款热门一站式团队协作工具

“常见的几种团队协作工具有&#xff1a;Zoho Projects、Slack、Microsoft Teams、Asana、Trello等。” 团队协作已经成为了企业、组织和个人工作的重要组成部分。为了提高工作效率和协同能力&#xff0c;各种团队协作工具应运而生。本文将介绍团队协作工具的功能以及常见的几种…

LeetCode——有效的括号

这里&#xff0c;我提供一种用栈来解决的方法&#xff1a; 思路&#xff1a;栈的结构是先进后出&#xff0c;这样我们就可以模拟栈结构了&#xff0c;如果是‘&#xff08;’、‘{’、‘[’任何一种&#xff0c;直接push进栈就可以了&#xff0c;如果是‘}’、‘&#xff09;’…