摘录自 《windows 核心编程》:
用户读注册表时调用RegOpenKeyEx,向其传入KEY_QUERY_VALUE,指定查询子项数据的权限。
然后,有些程序员在调用RegOpenKeyEx 函数的时候传入KEY_ALL_ACCESS作为期望的访问权限。
之所以这样做,是由于它简单,不需要动脑筋想权限的问题。
但是这样做的问题在于,对于一个不是管理员的标准用户,注册表项(比如HKLM)也许是只读的。
所以这样的应用程序在Windows Visita 上运行时,调用RegOpenKeyEx 传入KEY_ALL_ACCESS就会失败。
如果没有正确的错误检查,运行这样的程序会得到不可预料的结果。
其实,开发人员只需要稍微注意一下安全性,将KEY_ALL_ACCESS改为KEY_QUERY_VALUE,应用程序就能在所有的平台上正常运行了。