VerifyVersionInfoW 함수(winbase.h)
운영 체제 버전 요구 사항 집합을 현재 실행 중인 시스템 버전의 해당 값과 비교합니다. 이 함수는 매니페스트 기반 동작의 적용을 받습니다. 자세한 내용은 설명 섹션을 참조하세요.
참고: 이 함수는 Windows 10에서 더 이상 사용되지 않습니다. 자세한 내용은 Windows 애플리케이션을 대상으로 하는
통사론
BOOL VerifyVersionInfoW(
[in] LPOSVERSIONINFOEXW lpVersionInformation,
[in] DWORD dwTypeMask,
[in] DWORDLONG dwlConditionMask
);
매개 변수
[in] lpVersionInformation
비교할 운영 체제 버전 요구 사항이 포함된 OSVERSIONINFOEX 구조체에 대한 포인터입니다. dwTypeMask 매개 변수는 비교할 정보가 포함된 이 구조체의 멤버를 나타냅니다.
이 구조체의 dwOSVersionInfoSize 멤버를 sizeof(OSVERSIONINFOEX)
설정해야 합니다. 또한 dwTypeMask표시된 멤버에 대해 유효한 데이터를 지정해야 합니다. 함수는 해당 dwTypeMask 비트가 설정되지 않은 구조체 멤버를 무시합니다.
[in] dwTypeMask
테스트할 OSVERSIONINFOEX 구조체의 멤버를 나타내는 마스크입니다. 이 매개 변수는 다음 값 중 하나 이상일 수 있습니다.
[in] dwlConditionMask
비교할 각 lpVersionInfo 멤버에 사용할 비교 유형입니다. 이 값을 빌드하려면 비교할 각 OSVERSIONINFOEX 멤버에 대해 VerSetConditionMask 함수 또는 VER_SET_CONDITION 매크로를 한 번 호출합니다.
반환 값
현재 실행 중인 운영 체제가 지정된 요구 사항을 충족하는 경우 반환 값은 0이 아닌 값입니다.
현재 시스템이 요구 사항을 충족하지 않으면 반환 값이 0이고 GetLastError ERROR_OLD_WIN_VERSION 반환할
함수가 실패하면 반환 값이 0이고 getLastError
발언
VerifyVersionInfo 함수는 현재 실행 중인 운영 체제에 대한 버전 정보를 검색하고 lpVersionInfo 구조의 유효한 멤버와 비교합니다. 이렇게 하면 필요한 운영 체제 버전 조건 집합이 있는지 쉽게 확인할 수 있습니다.
일반적으로 verifyVersionInfo
함수는 주 버전, 부 버전 및 서비스 팩 버전 순서로 이러한 값을 테스트합니다. 함수는 같은 동안 값을 계속 테스트하고 값 중 하나가 지정된 조건을 충족하지 않으면 중지됩니다. 예를 들어 버전 5.1 서비스 팩 1보다 크거나 같은 시스템을 테스트하는 경우 현재 버전이 6.0인 경우 테스트가 성공합니다. 주 버전이 지정된 버전보다 크므로 테스트가 중지됩니다. 동일한 방식으로 버전 5.1 서비스 팩 1보다 크거나 같은 시스템을 테스트하는 경우 현재 버전이 5.2이면 테스트가 성공합니다. 부 버전은 지정된 버전보다 크므로 테스트가 중지됩니다. 그러나 버전 5.1 서비스 팩 1보다 크거나 같은 시스템을 테스트하는 경우 현재 버전이 5.0 서비스 팩 2인 경우 테스트가 실패합니다. 부 버전은 지정된 버전보다 크지 않으므로 테스트가 중지됩니다.
시스템 버전 범위를 확인하려면 VerifyVersionInfo 두 번 호출해야 합니다. 예를 들어 시스템 버전이 5.0보다 크지만 5.1보다 작거나 같은지 확인하려면 먼저 verifyVersionInfo
일반적으로 특정 운영 체제 기능이 있는지 여부를 확인하는 가장 좋은 방법은 현재 운영 체제를 식별하는 것이 아닙니다. 이는 운영 체제에 재배포 가능 DLL에 새로운 기능이 추가되었을 수 있기 때문입니다. GetVersionEx 사용하여 운영 체제 플랫폼 또는 버전 번호를 확인하는 대신 기능 자체의 존재를 테스트합니다. 자세한 내용은 운영 체제 버전참조하세요.
현재 운영 체제가 Media Center 또는 Tablet PC 버전의 Windows인지 확인하려면 GetSystemMetrics호출합니다.
Windows 10: VerifyVersionInfo 현재 운영 체제 버전이 Windows 8.1 또는 Windows 10인 경우에도 Windows 8.1 또는 Windows 10을 지정하도록 lpVersionInfo 매개 변수가 설정된 경우 Windows 8.1 또는 Windows 10에 대한 호환성 매니페스트가 없는 애플리케이션에서 호출할 때 false를 반환합니다. 특히 VerifyVersionInfo
- 애플리케이션에 매니페스트가 없는 경우 VerifyVersionInfo 운영 체제 버전이 Windows 8(6.2)인 것처럼 동작합니다.
- 애플리케이션에 Windows 8.1에 해당하는 GUID가 포함된 매니페스트가 있는 경우 VerifyVersionInfo 운영 체제 버전이 Windows 8.1(6.3)인 것처럼 동작합니다.
- 애플리케이션에 Windows 10에 해당하는 GUID가 포함된 매니페스트가 있는 경우 VerifyVersionInfo 운영 체제 버전이 Windows 10(10.0)인 것처럼 동작합니다.
Windows 8.1 또는 Windows 10용 애플리케이션을 매니페스트하려면 Windows애플리케이션을 대상으로 지정하는
예제
예를 들어 시스템 버전확인하세요.
메모
winbase.h 헤더는 VERIFYVersionInfo를 UNICODE 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows 2000 Server [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | winbase.h(Windows.h 포함) |
라이브러리 | Kernel32.lib |
DLL | Kernel32.dll |
참고 항목
GetVersionEx
OSVERSIONINFOEX
VerSetConditionMask