中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Visual C++ > 进程和线程
VC++中实现程序互斥运行
作者:iBreathe 时间:2001-10-09 10:09 出处:互联网 责编:chinaitpower
              摘要:VC++中实现程序互斥运行

                                             VC++中实现程序互斥运行

在软件的开发过程中,有时需要控制一些程序不能同时运行,也就是多个程序间互斥运行(还包括禁止同一程序运行多个实例)。针对这一问题,我们在Visual C++ 6.0中利用内存映射文件实现了多个程序间的互斥运行。

  在讲述具体的编程方法之前,让我们先来看看和内存映射文件操作有关的几个重要的函数:

  1)CreateFileMapping函数为指定的文件创建一个文件映射对象,该函数的原型如下:

  HANDLE CreateFileMapping(

   HANDLE hFile, // 用于映射的文件句柄

   LPSECURITY_ATTRIBUTES lpFileMappingAttributes, // 内存映射文件的安全描述符

   DWORD flProtect, // 文件的保护方式

   DWORD dwMaximumSizeHigh,

  // 文件映射对象的最大长度的高32位

   DWORD dwMaximumSizeLow,

  // 最大长度的低32位

   LPCTSTR lpName      

  // 指定这个内存映射文件的名字

  );

  2)MapViewOfFile函数将文件的视图映射到一个进程的地址空间上,返回LPVOID类型的内存指针,通过它,就可以直接访问文件视图中的信息:

  LPVOID MapViewOfFile(

   HANDLE hFileMappingObjct,    

    // 映射文件对象句柄

   DWORD dwDesiredAccess, // 访问模式

   DWORD dwFileOffsetHigh,      

  // 文件偏移地址的高32位

   DWORD dwFileOffsetLow,      

  // 文件偏移地址的低32位

   DWORD dwNumberOfBytesToMap  

  // 映射视图的大小

  );

  在Visual C++ 6.0中我们用默认方式生成基于对话框的应用程序,在程序的初始化阶段,在CwinApp派生类的InitInstance函数的开始处,添加以下代码:

  { HANDLE hMap=CreateFileMapping((HANDLE)0xFFFFFFFF, NULL,

PAGE—READWRITE, 0, 128, ″MutexRunning″);

  if(hMap==NULL) // 如果创建失败

{ AfxMessageBox(″创建用于互斥运行的内存映射文件对象失败!″,

MB—OK|MB—ICONSTOP);

return FALSE; }

else if(GetLastError()==ERROR—ALREADY—EXISTS)

{ LPVOID lpMem=MapViewOfFile(hMap, FILE_MAP—WRITE, 0,0,0);

CString str=(char)lpMem;

UnmapViewOfFile(lpMem);

CloseHandle(hMap);

AfxMessageBox(str, MB—OK|MB—ICONSTOP);

return FALSE; }

else

{ LPVOID lpMem=MapViewOfFile(hMap, FILE—MAP—WRITE, 0,0,0);

strcpy((char)lpMem, ″xxx程序正在运行!″);

UnmapViewOfFile(lpMem);

}

AfxEnableControlContainer();

  ......

  这里可以在InitInstance函数最后returnFALSE之前调用

   CloseHandle(hMap);

  关闭内存映射文件对象句柄

return FALSE;

  }

  以上的程序在Visual C++ 6.0中已调试通过。
 

 

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有