- 浏览: 768781 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (1045)
- 数据结构 (36)
- UML与设计模式 (42)
- c++ (87)
- rust (36)
- Qt (41)
- boost模板元编程 (43)
- Linux (77)
- 汇编 (4)
- 其它 (2)
- 烹饪 (3)
- unix c / socket (73)
- 软件工程 (4)
- shell (53)
- Python (37)
- c++ primer 5th(c++11) (22)
- 数据库/MySQL (27)
- 数据存储 (4)
- lisp (7)
- git (4)
- Utility (3)
- CDN与DNS (54)
- Http (53)
- php (7)
- nginx/lua/openresty (41)
- redis (11)
- TCP/IP (16)
- 互联网 (6)
- kernel (2)
- go (34)
- 区块链 (43)
- 比特股 (13)
- 以太坊 (23)
- 比特币 (23)
- 密码学 (10)
- EOS (53)
- DAG (1)
- docker (1)
- filecoin (7)
- solidity (65)
- ipfs (8)
- 零知识证明 (1)
- openzeppelin (3)
- java (1)
- defi (7)
- Ton (0)
最新评论
SharedMemory.h
SharedMemory.cpp
testSharedMemory.cpp
#ifndef SHAREDMEMORY_H #define SHAREDMEMORY_H namespace Utility { //获取shmId int initShm(const char* fileName); //清除shmId int closeShmMessage(int shmId); //向shmId写数据 int writeShmMessage(int shmId,const void* msg,int msgLen); //从shmId读数据 void* readShmMessage(int shmId); }//end of namespace Utility #endif // SHAREDMEMORY_H
SharedMemory.cpp
#include "SharedMemory.h" #include <sys/types.h> #include <sys/shm.h> #include <unistd.h> #include <string.h> #include <fcntl.h> namespace Utility { /* 获取shmId */ int initShm(const char* fileName) { if(access(fileName,R_OK)!=0) { int fd = open(fileName,O_RDWR|O_CREAT|O_APPEND); close(fd); } key_t key = ftok(fileName,0); if(key==-1){ return -1; } return shmget(key,4096,IPC_CREAT); } /* 清除shmId */ int closeShmMessage(int shmId) { return shmctl(shmId,IPC_RMID,0); } /* 向shmId写数据 */ int writeShmMessage(int shmId,const void* msg,int msgLen) { void *pmessage = shmat(shmId,NULL,0); memcpy(pmessage, msg, msgLen); if(shmdt(pmessage)==-1){ return -1; } return 0; } /* 从shmId读数据 */ void* readShmMessage(int shmId) { return shmat(shmId,NULL,0); } }//end of namespace Utility
testSharedMemory.cpp
#include <iostream> #include <string.h> #include <unistd.h> #include <sys/wait.h> #include <stdlib.h> #include "SharedMemory.h" using namespace std; using namespace Utility; struct Message { int m; char str[32]; }; static const char* g_file = "testShm"; int main() { Message msg1; msg1.m = 1; strcpy(msg1.str,"hello"); int shmId = initShm(g_file); if(shmId<0) { cout << "shmget error" << endl; return -1; } pid_t pid; if((pid=fork())==0) { writeShmMessage(shmId,&msg1,sizeof(msg1)); exit(0); } if(waitpid(pid,NULL,0)!=pid) { cout << "wait error" << endl; return -1; } Message* msg2 = (Message* )readShmMessage(shmId); cout << msg2->m << "," << msg2->str << endl; cout << "clear:" << closeShmMessage(shmId) << endl; return 0; } 1,hello clear:0
发表评论
-
滑动窗口与拥塞控制
2017-09-29 14:47 762滑动窗口:用作流量控制: 1.发送端和接收端各维护一个独立的发 ... -
rawsocket发送tcp包
2017-09-25 11:52 987testTcp.h #ifndef TESTTCP_H ... -
柔性数组
2017-09-20 09:53 511#include <iostream> #i ... -
rawsocket发送dns包
2017-09-14 15:18 618#include <stdio.h> #in ... -
rawsocket发送icmp包
2017-09-06 09:54 665#include <stdio.h> #in ... -
netfilter
2016-10-04 20:31 484http://blog.chinaunix.net/uid-2 ... -
gdb的简单使用
2016-09-19 15:18 419注意编译的时间加上-g参数 1.调试运行 gdb a.out ... -
TCP各状态的意义
2016-03-01 14:06 425各个状态的意义如下: LISTEN - 侦听来自远方TCP端 ... -
log
2015-03-30 17:42 457log.h #ifndef __LOG_H__ #def ... -
TIMEWAIT与CLOSEWAIT
2015-03-17 11:32 665http://blog.csdn.net/kobejayand ... -
TcpClient
2015-01-16 17:46 476TcpClient.h #ifndef TCPCLIENT ... -
信号量
2014-09-26 10:20 686#include <semaphore.h> ... -
记录锁
2014-09-11 16:32 442#include <errno.h> #in ... -
popen
2014-09-06 14:50 643#include <stdio.h> #in ... -
大小端存储
2014-09-05 09:29 609#include <stdio.h> i ... -
条件变量(cond)
2014-09-01 11:02 887#include <pthread.h> # ... -
读写锁
2014-09-01 10:33 734#include <pthread.h> # ... -
trylock
2014-09-01 10:07 674#include <pthread.h> # ... -
线程分离
2014-09-01 10:00 698http://www.cnblogs.com/mydomain ... -
线程返回值传出
2014-08-31 09:56 537#include <pthread.h> # ...
相关推荐
共享内存,顾名思义就是允许两个不相关的进程访问同一个逻辑内存,共享内存是两个正在运行的进程之间共享和传递数据的一种非常有效的方式。不同进程之间共享的内存通常为同一段物理内存。进程可以将同一段物理内存...
标题提到的"共享内存通讯,共享内存通讯源码,C,C++",表明我们将探讨的是如何使用C和C++编程语言实现基于共享内存的进程间通信。 首先,让我们理解什么是共享内存。共享内存是进程间通信(IPC,Inter-Process ...
在标题和描述中提到的"基于stl共享内存,可以像使用STL容器一样使用共享内存",指的是通过设计一个自定义的内存分配器(Allocator),使得STL容器如vector、list、map等能够在共享内存上进行操作。这种方式的优势...
在VB中实现共享内存,我们需要借助Windows API(应用程序接口)来完成,因为VB原生并不直接支持共享内存。API函数`CreateFileMapping`和`MapViewOfFile`是创建和映射共享内存的关键。`CreateFileMapping`函数用于...
共享内存是一种高效的数据交换方式,它允许多个进程直接访问同一块物理内存,而无需通过传统的I/O操作。本文将深入探讨如何在Android中利用C++实现共享内存,并结合Binder机制进行跨进程通信。 首先,我们需要了解...
共享内存是一种高效的进程间通信(IPC)机制,它允许不同的进程访问同一块内存空间,从而实现数据的快速交换。在Windows环境下,如VC6.0这样的开发工具可以用来编写和测试这种通信方式的代码。 首先,我们要理解...
本文将重点探讨在C#环境中如何利用共享内存进行进程间通信,这对于理解和优化多进程应用的性能至关重要。 共享内存是一种高效的IPC机制,它允许多个进程直接读写同一块内存区域,而无需通过任何中间媒介。在C#中,...
在Windows平台上,C++共享内存是一种高效的进程间通信(IPC, Inter-Process Communication)方法,允许不同的进程访问同一块内存区域。本项目提供了一个已经封装为C++类的实现,使得服务端可以写入数据,而客户端则...
C#共享内存的实例,附源码和工程文件。 网上有C#的共享内存类,不过功能太简单了。 故,对此进行了改进。通过利用共享内存的一部分空间来存储当前内存中存储的数据信息(count和length),完成了对内存读写功能的...
在IT领域,共享内存是一种高效的进程间通信(IPC)机制,允许不同的进程访问同一块内存空间,从而实现数据的快速交换。在这个"C#实现共享内存通讯交互"的项目中,我们将探讨如何使用C#语言来实现在WinForms应用程序...
在Windows系统中,File Mapping(文件映射)是实现共享内存的一种方式,它允许多个进程访问同一块物理内存,极大地提高了效率。本篇将深入讲解C++中使用File Mapping进行进程间通信的示例。 共享内存是IPC方法之一...
ShareMemLib将共享内存代码封装成lib,定义了发送者和监听者 两个进程在实例化ShareMemory时指定相同的map,并指定当前为发送者或监听者 发送者负责发送消息,监听者负责接受消息(监听者务必实现接受消息处理方法) ...
在C#中,实现进程间通信有多种方法,如管道、套接字、消息队列等,而共享内存是其中一种高效且直接的方式。本篇文章将深入探讨C#中的共享内存实现,并通过一个具体的代码实例来阐述其工作原理。 共享内存是一种让多...
### Linux共享内存浅析 #### 共享内存概述 共享内存是进程间通信(IPC)的一种方式,通过在内核中开辟一块特定的内存区域,允许多个进程对其进行访问,以此实现数据的共享和传递。相比其他进程间通信机制,共享...
在Linux中,可以使用`shmget`函数创建共享内存,`shmat`函数将共享内存附加到进程的地址空间,而`shmdt`用于解除对共享内存的附加。此外,`shmctl`用于管理共享内存段,例如删除或调整大小。 **信号量** 是一个整型...
在 Kubernetes 中,Pod 间实现共享内存的解决方案 在 Kubernetes 中,Pod 间实现共享内存是实现高性能和低耦合性的重要解决方案。文章中,我们将讨论为什么要将公共基础组件 Agent 进行 DaemonSet 部署,Linux 共享...
在IT领域,尤其是在多进程编程中,C语言的共享内存是一种高效的数据通信方式,它允许两个或多个进程之间共享同一块内存空间,从而实现数据的快速传输。在Linux操作系统环境下,这种技术通常依赖于POSIX标准提供的...
共享内存是一种高效的进程间通信(IPC)方式,它允许不同的进程直接访问同一块物理内存,无需通过传统的数据复制和传递。在本项目中,我们利用Visual Studio 2010开发环境来实现这一机制,这涉及到Windows API中的...
在Windows、Linux等操作系统上,多种IPC机制被广泛使用,其中包括管道、信号量、消息队列、套接字以及共享内存等。本实例将聚焦于共享内存,一种高效且直接的IPC方法,特别适用于需要高速数据交换的场景。 共享内存...
本项目聚焦于“利用共享内存实现进程通信”,这是一种高效且直接的数据交换方式,尤其适用于需要快速同步和数据交换的进程之间。我们将深入探讨如何在VC++环境下,结合MFC(Microsoft Foundation Classes)库来实现...