命名对象继承1-验证Create*命名对象安全属性的传递
来源:互联网 发布:mac ps2017怎么破解 编辑:程序博客网 时间:2024/05/29 12:40
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个值不同,所以命名对象句柄的安全性继承失败
0 0
- 命名对象继承1-验证Create*命名对象安全属性的传递
- 命名对象继承2-验证Open*命名对象安全属性的传递
- 游戏对象的属性与命名
- js对象属性的命名规则
- 对象,类,命名空间,继承......
- 对象命名
- 继承模式,命名空间,对象枚举
- javaScript中对象的属性名命名规则
- javascript对象属性命名“”增添的特殊情况
- 变量声明时命名与变量作为对象属性时命名的区别解析
- BW对象的命名空间
- 命名复杂的SQL对象
- 数据对象的命名笔记
- python对象的命名方法
- 面向对象的命名总结
- 面向对象进阶 01 对象、类、属性,方法、命名空间
- 模式对象的命名规则和命名空间
- 数据库对象命名规范
- 坑爹的tp-link管理密码设置
- 在linux单机上手动创建Oracle 10g物理standby dataguard
- 一个函数重载问题
- 隐藏进程名
- 讨论c/c++计算小数的精度问题
- 命名对象继承1-验证Create*命名对象安全属性的传递
- Arcgis 控制地图缩放比例
- 命名对象继承2-验证Open*命名对象安全属性的传递
- c++中不需要显示指出struct
- mknod 详解
- 收藏5篇文章
- 收藏的关于开发的一些东西
- 反驳--(知乎)大龄门外汉如何进入软件开发行业?的回复
- 一段挂起进程中所有线程的代码