win平台多用户访问共享内存、互斥锁

本文详细解析在Windows平台下,如何使不同用户和session中的进程能够共享同一把互斥锁或同一块共享内存。通过在MutexName前添加Global前缀,并设置安全权限,确保所有用户都能访问同一资源。
摘要由CSDN通过智能技术生成

文章目录

概述

在win平台下,如果要多进程共享访问同一把互斥,则使用有名CreateMutex或者有名CreateFileMapping。

例如:

HANDLE mutex = CreateMutexA(NULL, false, "MyMutexName"); 

使用上面的代码在同一个用户、同一个session下是没有问题的,但是以不同用户或者同一用户不同session时(比如在windows server中运行程序,使用远程桌面登录时,不同的远程桌面终端的MutexName是不同的),此mutex就不是同一个了。

因为不同用户或者session中实际生成的MutexName就有一个前缀,类似:

\session\1\basenamedobjs\MyMutexName
\session\9\basenamedobjs\MyMutexName

解决方案

此时如果希望不同的用户访问的是同一把锁,同一块共享内存,则需要在名称前加"Global",比如:

HANDLE mutex = CreateMutexA(NULL, false, "Global\\MyMutexName"); 

但是只做上一步是不完整的,因为不同的用户的权限不一样,使用OpenMutex时会提示无权限访问,此时就需要在CreateMutex时设置安全权限。

示例代码如下,在示例代码中创建了一个空的DACL,表示所有人都可以访问这块共享内存或者锁,暂时没有仔细研究精细控制权限:

code 1:

SECURITY_ATTRIBUTES sa = { sizeof(sa) }; 
SECURITY_DESCRIPTOR sd; 
InitializeSecurityDescriptor(&sd, SECURITY_DESCRIPTOR_REVISION); 
SetSecurityDescriptorDacl(&sd, TRUE, NULL, FALSE); 
sa.lpSecurityDescriptor = &sd; 

HANDLE mutex = CreateMutexA(&sa, 0, "Global\\MyMutexName"); 

code2:

SECURITY_ATTRIBUTES sa;
SECURITY_DESCRIPTOR sd;

InitializeSecurityDescriptor(&sd,SECURITY_DESCRIPTOR_REVISION);
SetSecurityDescriptorDacl(&sd,TRUE,NULL,FALSE);
sa.nLength = sizeof(SECURITY_ATTRIBUTES);
sa.bInheritHandle = TRUE;
sa.lpSecurityDescriptor = &sd;

CreateFileMapping(.., &sa,...);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值