进程间同步(互斥) 以及 同一DLL的不同进程copy共享全局变量

本文介绍如何使用进程间互斥(以mutex为例)实现COM组件的同步,并探讨在同一DLL中如何通过共享数据段让不同进程共享全局变量。通过CreateMutex创建一个全局的mutex对象,确保同一时间只有一个进程能访问特定函数。另外,利用#pragma data_seg预处理指令在DLL中定义共享数据段,使得所有加载该DLL的进程都能访问和共享这些变量。
摘要由CSDN通过智能技术生成

     此前遇到一个问题,希望实现一个COM组件,能够被不同的AP调用,同时需要他们保持同步。比较好的方式是采用ATL实现singleton的Com组件,很遗憾,这部分并不熟悉,只是依照codeproject上的sample"葫芦"画了一个瓢。看起来是可以用,大概的流程也清楚,但是说起ATL,根本没看过。

     那好吧,既然互斥就可以了,那就挑简单的,实现一个普通的COM组件/DLL,利用进程间互斥来实现他们的同步。进程间互斥的方法很多,包括内存文件映射、信号量等,通常用的是信号量,信号量的种类很多,譬如mutex,event,criticalsection等等。这里以mutex为例,简单实现了进程间互斥。

    互斥的核心思想是创建一个共享的信号量,只能被一个进程独占,而在已经被一个进程独占的时候,其他进程需要等待此信号量,直到占用此信号量的进程释放他。进程间之所以能够共享某一信号量,主要是因为信号量是一个内核对象,在进程中看到的是他在某个进程空间中的一个映射handle,在不同的进程空间映射的handle可能不同,但是在内核空间他们是同一个对象,也就是通过不同进程空间的不同handle去操作同一个内核对象。

    以mutex为例,可以通过CreateMutex来创建一个有名字的mutex的handle,如果此前没有其他程序创建过,系统会创建此mutex,并返回

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值