windows核心编程 第5版 48页 下半部写道
进程B调用CreateMutex时,它会向函数传递安全属性信息和第二参数。如果已经存在一个指定名称的对象,这些对象就会被忽略
于是我通过代码来验证这句话
注意 第47页
这个函数调用创建一个新的互斥量内核对象,并将其命名为“JeffMutex”。注意,在进程A的句柄(表)中,hMutexProcessA并不是一个可继承的句柄-但是通过为对象命名来实现共享时,是否可以继承并非一个必要条件。
HANDLE hMutex1 = CreateMutex(NULL, FALSE, TEXT("JeffObj")); //创建命名对象句柄1 SECURITY_ATTRIBUTES sa; //设置句柄安全性 sa.nLength = sizeof(sa); sa.lpSecurityDescriptor = NULL; sa.bInheritHandle = TRUE; HANDLE hMutex2 = CreateMutex(&sa, FALSE, TEXT("JeffObj")); //创建对象句柄2 DWORD a; if ((a = GetLastError()) == ERROR_ALREADY_EXISTS){ //判断创建对象句柄2是创建一个对象句柄还是调用对象句柄1 } else { } DWORD dwFlags1; GetHandleInformation(hMutex1, &dwFlags1); //验证对象句柄1的安全性是否为可继承 BOOL fHandleIsInheritable1 = (0 != (dwFlags1 & HANDLE_FLAG_INHERIT)); DWORD dwFlags2; GetHandleInformation(hMutex2, &dwFlags2); //验证对象句柄2的安全性是否为可继承,判断继承安全性是否成功 BOOL fHandleIsInheritable2 = (0 != (dwFlags2 & HANDLE_FLAG_INHERIT)); CloseHandle(hMutex1); CloseHandle(hMutex2);
结果下图
通过fHandleIsInheritable1和fHandleIsInheritable2 的值可以看到,2个值不同,所以命名对象句柄的安全性继承失败