共享内存操作类(C#源码)

简介:

VC++的共享内存操作代码实现起来相对比较容易,但是用C#语言来实现,就有一定难度,由于工作需要,把以前VC开发的共享内存代码要用C#实现,别说,还费了不少周折,毕竟C#操作API函数和地址指针不是那么直接,还好,总算完成了,效果还不错。

    

共享内存操作类:    

 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4. using System.Runtime.InteropServices;  
  5.  
  6. namespace ShareMemLib  
  7. {  
  8.     public class ShareMem  
  9.     {  
  10.         [DllImport("user32.dll", CharSet = CharSet.Auto)]  
  11.         public static extern IntPtr SendMessage(IntPtr hWnd, int Msg, int wParam, IntPtr lParam);  
  12.  
  13.         [DllImport("Kernel32.dll", CharSet = CharSet.Auto)]  
  14.         public static extern IntPtr CreateFileMapping(int hFile, IntPtr lpAttributes, uint flProtect, uint dwMaxSizeHi, uint dwMaxSizeLow, string lpName);  
  15.           
  16.         [DllImport("Kernel32.dll", CharSet = CharSet.Auto)]  
  17.         public static extern IntPtr OpenFileMapping(int dwDesiredAccess,[MarshalAs(UnmanagedType.Bool)] bool bInheritHandle,string lpName);  
  18.  
  19.         [DllImport("Kernel32.dll", CharSet = CharSet.Auto)]  
  20.         public static extern IntPtr MapViewOfFile(IntPtr hFileMapping,uint dwDesiredAccess, uint dwFileOffsetHigh, uint dwFileOffsetLow,uint dwNumberOfBytesToMap);  
  21.  
  22.         [DllImport("Kernel32.dll", CharSet = CharSet.Auto)]  
  23.         public static extern bool UnmapViewOfFile(IntPtr pvBaseAddress);  
  24.  
  25.         [DllImport("Kernel32.dll", CharSet = CharSet.Auto)]  
  26.         public static extern bool CloseHandle(IntPtr handle);  
  27.  
  28.         [DllImport("kernel32", EntryPoint="GetLastError")]  
  29.         public static extern int GetLastError ();  
  30.  
  31.         const int ERROR_ALREADY_EXISTS = 183;  
  32.  
  33.         const int FILE_MAP_COPY = 0x0001;  
  34.         const int FILE_MAP_WRITE = 0x0002;  
  35.         const int FILE_MAP_READ = 0x0004;  
  36.         const int FILE_MAP_ALL_ACCESS = 0x0002 | 0x0004;  
  37.  
  38.         const int PAGE_READONLY = 0x02;  
  39.         const int PAGE_READWRITE = 0x04;  
  40.         const int PAGE_WRITECOPY = 0x08;  
  41.         const int PAGE_EXECUTE = 0x10;  
  42.         const int PAGE_EXECUTE_READ = 0x20;  
  43.         const int PAGE_EXECUTE_READWRITE = 0x40;  
  44.  
  45.         const int SEC_COMMIT = 0x8000000;  
  46.         const int SEC_IMAGE = 0x1000000;  
  47.         const int SEC_NOCACHE = 0x10000000;  
  48.         const int SEC_RESERVE = 0x4000000;  
  49.  
  50.         const int INVALID_HANDLE_VALUE = -1;  
  51.  
  52.         IntPtr m_hSharedMemoryFile = IntPtr.Zero;  
  53.         IntPtr m_pwData = IntPtr.Zero;  
  54.         bool m_bAlreadyExist = false;  
  55.         bool m_bInit = false;  
  56.         long m_MemSize=0;  
  57.  
  58.         public ShareMem()  
  59.         {  
  60.         }  
  61.         ~ShareMem()  
  62.         {  
  63.             Close();  
  64.         }  
  65.  
  66.         /// <summary>  
  67.         /// 初始化共享内存  
  68.         /// </summary>  
  69.         /// <param name="strName">共享内存名称</param>  
  70.         /// <param name="lngSize">共享内存大小</param>  
  71.         /// <returns></returns>  
  72.         public int Init(string strName, long lngSize)  
  73.         {  
  74.             if (lngSize <= 0 || lngSize > 0x00800000) lngSize = 0x00800000;  
  75.             m_MemSize = lngSize;  
  76.             if (strName.Length > 0)  
  77.             {  
  78.                 //创建内存共享体(INVALID_HANDLE_VALUE)  
  79.                 m_hSharedMemoryFile = CreateFileMapping(INVALID_HANDLE_VALUE, IntPtr.Zero, (uint)PAGE_READWRITE, 0, (uint)lngSize, strName);  
  80.                 if (m_hSharedMemoryFile == IntPtr.Zero)  
  81.                 {  
  82.                     m_bAlreadyExist = false;  
  83.                     m_bInit = false;  
  84.                     return 2; //创建共享体失败  
  85.                 }  
  86.                 else 
  87.                 {  
  88.                     if (GetLastError() == ERROR_ALREADY_EXISTS)  //已经创建  
  89.                     {  
  90.                         m_bAlreadyExist = true;  
  91.                     }  
  92.                     else                                         //新创建  
  93.                     {  
  94.                         m_bAlreadyExist = false;  
  95.                     }  
  96.                 }  
  97.                 //---------------------------------------  
  98.                 //创建内存映射  
  99.                 m_pwData = MapViewOfFile(m_hSharedMemoryFile, FILE_MAP_WRITE, 0, 0, (uint)lngSize);  
  100.                 if (m_pwData == IntPtr.Zero)  
  101.                 {  
  102.                     m_bInit = false;  
  103.                     CloseHandle(m_hSharedMemoryFile);  
  104.                     return 3; //创建内存映射失败  
  105.                 }  
  106.                 else 
  107.                 {  
  108.                     m_bInit = true;  
  109.                     if (m_bAlreadyExist == false)  
  110.                     {  
  111.                         //初始化  
  112.                     }  
  113.                 }  
  114.                 //----------------------------------------  
  115.             }  
  116.             else 
  117.             {  
  118.                 return 1; //参数错误       
  119.             }  
  120.  
  121.             return 0;     //创建成功  
  122.         }  
  123.         /// <summary>  
  124.         /// 关闭共享内存  
  125.         /// </summary>  
  126.         public void Close()  
  127.         {  
  128.             if (m_bInit)  
  129.             {  
  130.                 UnmapViewOfFile(m_pwData);  
  131.                 CloseHandle(m_hSharedMemoryFile);  
  132.             }  
  133.         }  
  134.  
  135.         /// <summary>  
  136.         /// 读数据  
  137.         /// </summary>  
  138.         /// <param name="bytData">数据</param>  
  139.         /// <param name="lngAddr">起始地址</param>  
  140.         /// <param name="lngSize">个数</param>  
  141.         /// <returns></returns>  
  142.         public int Read(ref byte[] bytData, int lngAddr, int lngSize)  
  143.         {  
  144.             if (lngAddr + lngSize > m_MemSize) return 2; //超出数据区  
  145.             if (m_bInit)  
  146.             {                 
  147.                 Marshal.Copy(m_pwData, bytData, lngAddr, lngSize);  
  148.             }  
  149.             else 
  150.             {  
  151.                 return 1; //共享内存未初始化  
  152.             }  
  153.             return 0;     //读成功  
  154.         }  
  155.  
  156.         /// <summary>  
  157.         /// 写数据  
  158.         /// </summary>  
  159.         /// <param name="bytData">数据</param>  
  160.         /// <param name="lngAddr">起始地址</param>  
  161.         /// <param name="lngSize">个数</param>  
  162.         /// <returns></returns>  
  163.         public int Write(byte[] bytData, int lngAddr, int lngSize)  
  164.         {  
  165.             if (lngAddr + lngSize > m_MemSize) return 2; //超出数据区  
  166.             if (m_bInit)  
  167.             {  
  168.                 Marshal.Copy(bytData, lngAddr, m_pwData, lngSize);  
  169.             }  
  170.             else 
  171.             {  
  172.                 return 1; //共享内存未初始化  
  173.             }  
  174.             return 0;     //写成功  
  175.         }  
  176.     }  
  177. }  
  178.  
  179. 测试例程:   
  180.  
  181. using System;  
  182. using System.Collections.Generic;  
  183. using System.ComponentModel;  
  184. using System.Data;  
  185. using System.Drawing;  
  186. using System.Text;  
  187. using System.Windows.Forms;  
  188. using ShareMemLib;  
  189.  
  190. namespace YFShareMem  
  191. {  
  192.     public partial class frmShareMem : Form  
  193.     {  
  194.         ShareMem MemDB=new ShareMem();  
  195.         public frmShareMem()  
  196.         {  
  197.             InitializeComponent();  
  198.         }  
  199.  
  200.         private void btnOpen_Click(object sender, EventArgs e)  
  201.         {  
  202.             if (MemDB.Init("YFMemTest", 10240) != 0)  
  203.             {  
  204.                 //初始化失败  
  205.                 MessageBox.Show("初始化失败");  
  206.             }  
  207.             else 
  208.             {  
  209.                 btnOpen.Enabled = false;  
  210.                 chkWrite.Enabled = true;  
  211.                 tmrTime.Enabled = true;  
  212.             }  
  213.         }  
  214.  
  215.         private void tmrTime_Tick(object sender, EventArgs e)  
  216.         {  
  217.             byte[] bytData = new byte[16];  
  218.             int intRet = MemDB.Read(ref bytData, 0, 16);  
  219.             lstData.Items.Clear();   
  220.             if (intRet == 0)  
  221.             {  
  222.                 for (int i = 0; i < 16; i++)  
  223.                 {  
  224.                     lstData.Items.Add(bytData[i].ToString());  
  225.                 }  
  226.  
  227.                 if (chkWrite.Checked)  
  228.                 {  
  229.                     bytData[0]++;  
  230.                     bytData[1] += 2;  
  231.                     if (bytData[0] > 200) bytData[0] = 0;  
  232.                     if (bytData[1] > 200) bytData[1] = 0;  
  233.                     MemDB.Write(bytData, 0, 16);  
  234.                 }  
  235.             }             
  236.         }  
  237.  
  238.     }  
  239. }  
  240.  

 











本文转自yefanqiu51CTO博客,原文链接:http://blog.51cto.com/yfsoft/323427,如需转载请自行联系原作者

相关文章
|
8天前
|
数据采集 安全 JavaScript
C#医院手术麻醉信息管理系统源码 对接院内HIS、LIS、PACS
手麻系统的功能涵盖了麻醉临床业务管理、麻醉运营业务管理以及手术进程管理等,实现了将多种麻醉病历文书与医院HIS系统的有效关联,让手术室人员、设备资源和信息资源高度共享;实现了手术安排、各种统计报表等科室管理和科研工作的需求,可借其收集临床数据、进行整合分析,为围术期临床信息、管理、科研提供整体解决方案;该系统的运行,为医护人员提供了流程化、信息化、自动化、智能化的临床业务综合管理。
23 5
|
3月前
|
存储 C++
|
3月前
|
存储 传感器 监控
Baumer工业相机堡盟工业相机如何通过BGAPISDK将相机图像高速保存到电脑内存(C#)
Baumer工业相机堡盟工业相机如何通过BGAPISDK将相机图像高速保存到电脑内存(C#)
54 0
|
4天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
21天前
|
安全 JavaScript 前端开发
C#医院手麻系统源码,手术麻醉管理系统源码
手术麻醉管理系统贯穿患者入院至出院全程,整合术前术后流程,如手术排班、麻醉计划、术中监护及术后恢复。采用C#.net6.0、Vue、Ant-Design等技术,与sqlserver2019数据库结合。系统提供麻醉记录、手术安全核查、费用管理等功能,确保信息数字化和流程规范化。通过自动化记录和数据分析,增强手术安全,优化资源分配,并支持医疗质控与研究。
C#医院手麻系统源码,手术麻醉管理系统源码
|
23天前
|
存储 监控 安全
C#手术麻醉系统源码 大型医院手麻系统4大需求是什么?
C#编写的大型医院手术麻醉系统旨在满足四大核心需求:智慧医院建设,要求实时患者信息共享与监控;医院等级评级,强调安全评估与术后管理;电子病历评级,规定手术预约、麻醉信息的标准化;科室需求,包括系统互联、流程信息化、数据追溯、操作简便、文书完整、快速响应、生命体征动态采集及质量控制。系统提升手麻工作的效率与安全性,确保手术顺利进行。
|
1月前
|
数据挖掘 C# 开发工具
采用C#语言开发的全套医院体检系统PEIS源码功能介绍
体检系统,是专为体检中心/医院体检科等体检机构,专门开发的全流程管理系统,通过软件实现检测仪器数据自动提取,内置多级医生工作台,细化工作将体检检查结果汇总,生成体检报告登记到计算机系统中。通过软件系统进行数据分析统计与评判以及建立体检相关的体检档案。从而实现体检流程的信息化,提高工作效率,减少手动结果录入的一些常犯错误。 在实际应用中,医院体检系统能够解决传统体检中手工操作带来的问题,如工作量大、效率低下、易漏检、重检或错检等。通过与医院信息系统(如HIS、LIS、PACS等)的连接,系统能够满足体检中心的日常工作流程,提供更好的管理、统计和查询分析功能。同时,基于网络基础的系统可以在网上传输
23 1
|
2月前
|
前端开发 JavaScript BI
C#区域医院云LIS信息管理系统源码
区域医院云LIS可协助区域内所有临床实验室相互协调并完成日常检验工作,对区域内的检验数据进行集中管理和共享,通过对质量控制的管理,最终实现区域内检验结果互认。其目标是以医疗服务机构为主体,以医疗资源和检验信息共享为目标,集成共性技术及医疗服务关键技术,建立区域协同检验。
33 2
|
2月前
|
存储 编译器 程序员
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
105 0
|
2月前
|
开发框架 前端开发 NoSQL
C#医院区域云LIS系统源码
LIS操作流程标本流转----标本核收----标本上机检验----费用汇总----报告审核----报告发布----报告打印等基础流程
38 3