C#共享内存实例

网上有C#共享内存类,不过功能太简单了,并且写内存每次都从开头写。故对此进行了改进,并做了个小例子,供需要的人参考。

主要改进点:

通过利用共享内存的一部分空间(以下称为“数据信息区”)来存储当前内存中存储的数据信息(count和length或者添加其他信息),完成了对内存读写功能的完善。

在读写内存时,读写数据信息区。

1.写共享内存

根据共享内存当前的使用length,依次往后写。

2.读共享内存

读取从共享内存的起始位置(不包括数据信息区)至length的所有数据。

3.关键点

把IntPtr型的m_pwData当指针来操作,实现从内存的任意位置读写数据。

m_pwDataWrite = (IntPtr)(m_pwData.GetHashCode() + m_length + infoSize);

4.可改进处

在数据信息区,添加每条数据的length信息,即可实现自由读取数据,而不必每次都起始读。

实例截图如下:

时间: 2024-10-31 01:33:01

C#共享内存实例的相关文章

C#共享内存实例 附源码

原文 C#共享内存实例 附源码 网上有C#共享内存类,不过功能太简单了,并且写内存每次都从开头写.故对此进行了改进,并做了个小例子,供需要的人参考. 主要改进点: 通过利用共享内存的一部分空间(以下称为"数据信息区")来存储当前内存中存储的数据信息(count和length或者添加其他信息),完成了对内存读写功能的完善. 在读写内存时,读写数据信息区. 1.写共享内存 根据共享内存当前的使用length,依次往后写. 2.读共享内存 读取从共享内存的起始位置(不包括数据信息区)至len

win32下进程间通信(共享内存)实例分析_C 语言

一.概述 很多情况下在Windows程序中,各个进程之间往往需要交换数据,进行数据通讯.WIN32 API提供了许多函数使我们能够方便高效的进行进程间的通讯,通过这些函数我们可以控制不同进程间的数据交换. 进程间通讯(即:同机通讯)和数据交换有多种方式:消息.共享内存.匿名(命名)管道.邮槽.Windows套接字等多种技术."共享内存"(shared memory)可以定义为对一个以上的进程是可见的内存或存在于多个进程的虚拟地址空间.例如:如果两个进程使用相同的DLL,只把DLL的代码

PHP共享内存用法实例分析_php技巧

本文实例讲述了PHP共享内存用法.分享给大家供大家参考,具体如下: 共享内存主要用于进程间通信 php中的共享内存有两套扩展可以实现 1.shmop  编译时需要开启 --enable-shmop 参数 实例: $shm_key = ftok(__FILE__, 't'); /** 开辟一块共享内存 int $key , string $flags , int $mode , int $size $flags: a:访问只读内存段 c:创建一个新内存段,或者如果该内存段已存在,尝试打开它进行读写

Linux下C编程:共享内存通信实例

共享内存是LUNIX 系统中最底层的通信机制,也是最快速的通信机制.共享内存通过两个或多个进程共享同一块内存区域来实现进程间的通信.通常是由一个进程创建一块共享 内存区域,然后多个进程可以对其进行访问,一个进程将要传出的数据存放到共享内存中,另一个或多个进程则直接从共享内存中读取数据.因此这种通信方式是最高效的进程间通信方式.但实际的问题在于,当两个或多个进程使用共享内存进行通信时,同步问题的解决显得尤为重要,否则就会造成因不同进程同时读写一块共享内存中的数据而发生混乱.在通常的情况下,通过使用

Go语言共享内存读写实例分析_Golang

本文实例分析了Go语言共享内存读写的方法.分享给大家供大家参考.具体分析如下: 前面分析了Go语言指针运算和内嵌C代码的方法,做了一个Go语言共享内存读写的实验. 先大概说下什么是共享内存.我们知道不同进程见的内存是互相独立的,没办法直接互相操作对方内的数据,而共享内存则是靠操作系统提供的内存映射机制,让不同进程的一块地址空间映射到同一个虚拟内存区域上,使不同的进程可以操作到一块共用的内存块.共享内存是效率最高的进程间通讯机制,因为数据不需要在内核和程序之间复制. 共享内存用到的是系统提供的mm

Linux 进程间通讯共享内存方式

共享内存方式:从物理内存里面拿出来一部分作为多个进程共享. 共享内存是进程间共享数据的一种最快的方法,一个进程向共享内存区域写入数据,共享这个内存的所有进程都可以立即看到其中内容. 共享内存实现步骤: 一.创建共享内存,使用shmget函数. 二.映射共享内存,将这段创建的共享内存映射到具体的进程空间去,使用shmat函数. 创建共享内存shmget: intshmget(key_t key, size_t size, int shmflg) 功能:得到一个共享内存标识符或创建一个共享内存对象并

c++进程间通讯(共享内存)时

问题描述 c++进程间通讯(共享内存)时 我的需求:一个进程批量的数据不间断的存入差不多每秒有400k的数据这样子(不一定是一次存入的,可能是分几次),而另一个内存要从共享内存中读取这些数据,读取完就释放那块内存. 如何使共享的内存具有一定的数据结构,如同stl中的vector那样. 解决方案 需要自己做序列化,反序列化,把数据转回vector.自己定义格式等,知道多大一块内存数据表示一个vector的元素.然后一个个获取,存入vector 解决方案二: 如何使共享的内存具有一定的数据结构?共享

浅析Linux的共享内存与tmpfs文件系统

前言 共享内存主要用于进程间通信,Linux有两种共享内存(Shared Memory)机制: (1) ** System V shared memory(shmget/shmat/shmdt) ** Original shared memory mechanism, still widely used Sharing between unrelated processes. (2) ** POSIX shared memory(shm_open/shm_unlink) ** Sharing b

《DB2性能管理与实战》——2.2 数据库管理器共享内存

2.2 数据库管理器共享内存 DB2性能管理与实战 数据库管理器共享内存由若干个不同的内存区组成,可使用配置参数控制这些区域的大小.图2-2显示了数据库管理器共享内存的分配方式. 2.2.1 实例(数据库管理器)共享内存 每个DB2实例都有一个实例共享内存.实例共享内存是在数据库管理器启动(db2start)时分配的,并随着数据库管理器的停止(db2stop)而释放.这种内存集用于实例级的任务,例如监控.审计和节点间通信.下面的数据库管理器配置(dbm cfg)参数控制着对实例共享内存以及其中个