假設我正在寫一機多用的DLL,其中包括用於獲取操作系統版本的函數:從dll函數調用中正確獲取Windows版本?
void get_os_version(DWORD *major, DWORD *minor)
{
OSVERSIONINFOEX osvi;
ZeroMemory(&osvi, sizeof(OSVERSIONINFOEX));
osvi.dwOsVersionInfoSize = sizeof(OSVERSIONINFOEX);
// deprecated but easier to use for this example's sake
GetVersionEx((OSVERSIONINFO*)&osvi);
*major = osvi.dwMajorVersion;
*minor = osvi.dwMinorVersion;
}
對於Windows版本比Windows 8以上版本被正確檢索,需要嵌入清單,指定支持的平臺(請參閱詳細信息here)。
所以我禁用自動生成清單的編制時,使用/MANIFEST:NO
標誌我的DLL文件,而不是添加下面的清單:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
<security>
<requestedPrivileges>
<requestedExecutionLevel level="asInvoker" uiAccess="false"></requestedExecutionLevel>
</requestedPrivileges>
</security>
</trustInfo>
<compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1">
<application>
<!-- Windows 10 -->
<supportedOS Id="{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}"/>
<!-- Windows 8.1 -->
<supportedOS Id="{1f676c76-80e1-4239-95bb-83d0f6d0da78}"/>
<!-- Windows Vista -->
<supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"/>
<!-- Windows 7 -->
<supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>
<!-- Windows 8 -->
<supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"/>
</application>
</compatibility>
</assembly>
,使用MT工具:
mt -manifest GetOsVersion.dll.manifest -outputresource:GetOsVersion.dll;#2
一切順利,沒有錯誤。現在使用DLL,我創建了一個簡單的APP.EXE其加載DLL並調用其功能:
int _tmain(int argc, _TCHAR* argv[])
{
DWORD major, minor;
get_os_version(&major, &minor);
printf("%d.%d\n", major, minor);
return 0;
}
但在Windows 10,驚喜驚喜運行APP.EXE時,輸出爲:
6.2
,這是版本的Windows 8,如果我申請的艙單APP.EXE太:
mt -manifest GetOsVersion.dll.manifest -outputresource:App.exe;#1
,產量預期之一:
10.0
這是爲什麼發生?我可以在不向可執行文件添加清單的情況下解決此問題嗎?
我無法控制將使用我的庫的應用程序,但我仍然想要正確檢索操作系統版本。
+1謝謝,我會試試這個。注意:我不會在我的實際dll中導出這樣的函數,它會在dll中調用以進行統計和調試;我這樣做了這個例子,以便我可以很容易地展示問題 – Claudiu
好的,那是合法的用法。我不會編輯我的答案,因爲警告可能仍然與未來的讀者有關。 :-) –