有时候我们会遇到window进程间共享数据的需求,例如说我想知道系统当前有多少某个进程的实例。

我们能够在程序中定义一个全局变量。初始化为0。每当程序启动后就加1。当然我们我们能够借助第三方介质来储存这个变量,然后解析。

这样做必须做到先写入后解析。不能实时更新数据。假设不考虑其它储存介质。仅仅是进程中的通信,应该怎么做呢?windows提供了一些可行的方法,以下介绍经常使用的两种。

一、共享数据段

#include "stdafx.h"
#include <Windows.h> }; #pragma data_seg("Shared")
volatile int g_lAppInstances = 0 ;
#pragma data_seg() #pragma comment(linker, "/Section:Shared,RWS") int _tmain(int argc, _TCHAR* argv[])
{
printf("the instance of app is %d\n", ++g_lAppInstances) ;
getchar() ;
return 0;
}

以上就是在代码中增加共享数据段。当执行一个程序的实例的同一时候打开还有一个实例。g_lAppInstances会指向同一个内存,这样就能够做到数据共享。可是这样的方法的缺点是仅仅能共享一个变量的数据,对于结构体是不行的。

二、内存映射文件

第一个程序:

#include "stdafx.h"
#include <Windows.h> struct SharedData{
int a ;
int b;
float c ;
SharedData(int x, int y, float z){
a = x ;
b = y ;
c = z ;
}
}; const int BUF_SIZE = 256 ;
TCHAR szName[] = _T("Global\\MyFileMappingObj") ; int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hMapFile = CreateFileMapping(INVALID_HANDLE_VALUE,
NULL, PAGE_READWRITE, 0, BUF_SIZE, szName) ;
if(hMapFile == NULL){
_tprintf(_T("Could not create file mapping obj\n")) ;
return 1 ;
} LPCTSTR pBuf = (LPCTSTR)MapViewOfFile(hMapFile, FILE_MAP_ALL_ACCESS, 0, 0, BUF_SIZE) ;
if(pBuf == NULL){
_tprintf(_T("could not mapping file\n")) ;
CloseHandle(hMapFile) ;
return 2 ;
}
<span style="white-space:pre"> </span><pre name="code" class="cpp"><span style="white-space:pre"> </span>SharedData *pSd = (SharedData*)pBuf ;
_tprintf(_T("the data from IPC2 is %d, %d, %f\n"), pSd->a, pSd->b, pSd->c) ;
getchar() ;

UnmapViewOfFile(pBuf) ;CloseHandle(hMapFile) ;return 0;}


第二个程序:

#include "stdafx.h"
#include <Windows.h> struct SharedData{
int a ;
int b;
float c ;
SharedData(int x, int y, float z){
a = x ;
b = y ;
c = z ;
}
}; const int BUF_SIZE = 256 ;
TCHAR szName[] = _T("Global\\MyFileMappingObj") ; int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hMapFile = CreateFileMapping(INVALID_HANDLE_VALUE,
NULL, PAGE_READWRITE, 0, BUF_SIZE, szName) ;
if(hMapFile == NULL){
_tprintf(_T("Could not create file mapping obj\n")) ;
return 1 ;
} LPCTSTR pBuf = (LPCTSTR)MapViewOfFile(hMapFile, FILE_MAP_ALL_ACCESS, 0, 0, BUF_SIZE) ;
if(pBuf == NULL){
_tprintf(_T("could not mapping file\n")) ;
CloseHandle(hMapFile) ;
return 2 ;
} <pre name="code" class="cpp"><span style="white-space:pre"> </span>TCHAR s[BUF_SIZE] ;
SharedData sd(1, 2, 3.14) ;
memcpy((LPVOID)pBuf, &sd, sizeof(sd)) ;

UnmapViewOfFile(pBuf) ;CloseHandle(hMapFile) ;return 0;}


我们先执行第二个程序,然后再执行第一个程序,发现第一个程序打印出了第二个程序一个结构体的值,达到了数据共享的目的。

进程间的通信还包含剪切板,邮槽。管道等,可是他们本质上都是利用的内存映射文件实现的。

最新文章

  1. Bootstrap 4-alpha 初体验
  2. maven dependencies 里面的包怎么导出
  3. AspJpeg使用 .
  4. tone mapping简介
  5. Codeforces Round #367 (Div. 2) A B C 暴力 二分 dp(字符串的反转)
  6. Git忽略文件方法【转】
  7. Eclipse调试Java的10个技巧
  8. UIStepper使用的具体解释的控制
  9. WebSocket浅析(一):实现群聊功能
  10. Java设计模式:代理模式(二)
  11. 新ITC提交APP常见问题与解决方法(Icon Alpha,Build version,AppIcon120x120)(2014-11-17)
  12. selenium操作浏览器窗口最大化和刷新
  13. 光圈,快门, 曝光,焦距, ISO,景深。
  14. elementUI 时间格式化(一般方法)
  15. UVA10384-The Wall Pushers(迭代加深搜索)
  16. Python 学习 第九篇:模块
  17. window.location方法获取URL
  18. springboot static方法与构造方法加载@VALUE
  19. directive指令二 require:&#39;^ngModel&#39;
  20. MVC教程一:MVC简介

热门文章

  1. python算法-二叉树广度优先遍历
  2. git删除本地所有的更改
  3. ctype.h 第2章
  4. python3--__getattr__和__setattr__捕捉属性的一个引用
  5. 使用python实现简单的爬虫
  6. 刷题总结——保留道路(ssoj)
  7. 【2018.8.10】四连测day4 题解
  8. Spoj-BGSHOOT
  9. poj 2115 二元一次不定方程
  10. 家用电脑架服务器提供web