GetVersionExA, fonction (sysinfoapi.h)
getVersionExA peut être modifié ou indisponible pour les versions après Windows 8.1. Utilisez plutôt les fonctions d’assistance de version . Pour les applications Windows 10, consultez Ciblage de vos applications pour Windows.
Avec la version de Windows 8.1, le comportement de l’API GetVersionEx a changé dans la valeur qu’elle retourne pour la version du système d’exploitation. La valeur retournée par la fonction GetVersionEx dépend désormais de la façon dont l’application est manifeste.
Les applications non manifestes pour Windows 8.1 ou Windows 10 retournent la valeur de version du système d’exploitation Windows 8 (6.2). Une fois qu’une application est manifeste pour une version donnée du système d’exploitation, GetVersionEx retourne toujours la version pour laquelle l’application est manifeste dans les versions ultérieures. Pour manifester vos applications pour Windows 8.1 ou Windows 10, reportez-vous à Ciblage de votre application pour Windows.
Syntaxe
NOT_BUILD_WINDOWS_DEPRECATE BOOL GetVersionExA(
[in, out] LPOSVERSIONINFOA lpVersionInformation
);
Paramètres
[in, out] lpVersionInformation
Une structure OSVERSIONINFOA ou OSVERSIONINFOEXA qui reçoit les informations du système d’exploitation.
Avant d’appeler la fonction GetVersionEx, définissez la dwOSVersionInfoSize membre de la structure selon les besoins pour indiquer quelle structure de données est passée à cette fonction.
Valeur de retour
Si la fonction réussit, la valeur de retour est une valeur différente de zéro.
Si la fonction échoue, la valeur de retour est égale à zéro. Pour obtenir des informations d’erreur étendues, appelez GetLastError. La fonction échoue si vous spécifiez une valeur non valide pour le membre dwOSVersionInfoSize de la structure OSVERSIONINFOA ou osVERSIONINFOEXA.
Remarques
L’identification du système d’exploitation actuel n’est généralement pas la meilleure façon de déterminer si une fonctionnalité de système d’exploitation particulière est présente. Cela est dû au fait que le système d’exploitation a peut-être ajouté de nouvelles fonctionnalités dans une DLL redistribuable. Au lieu d’utiliser GetVersionEx pour déterminer la plateforme ou le numéro de version du système d’exploitation, testez la présence de la fonctionnalité elle-même. Pour plus d’informations, consultez version du système d’exploitation.
La fonction GetSystemMetrics fournit des informations supplémentaires sur le système d’exploitation actuel.
Produit | Réglage |
---|---|
Windows XP Media Center Edition | SM_MEDIACENTER |
Windows XP Starter Edition | SM_STARTER |
Windows XP Tablet PC Edition | SM_TABLETPC |
Windows Server 2003 R2 | SM_SERVERR2 |
Pour rechercher des systèmes d’exploitation ou des fonctionnalités de système d’exploitation spécifiques, utilisez la fonction IsOS. La fonction GetProductInfo récupère le type de produit.
Pour récupérer des informations sur le système d’exploitation sur un ordinateur distant, utilisez la fonction NetWkstaGetInfo
Pour comparer la version système actuelle à une version requise, utilisez la fonction VerifyVersionInfo au lieu d’utiliser GetVersionEx pour effectuer vous-même la comparaison.
Si le mode de compatibilité est en vigueur, la fonction GetVersionEx signale le système d’exploitation tel qu’il s’identifie, ce qui peut ne pas être le système d’exploitation installé. Par exemple, si le mode de compatibilité est en vigueur, GetVersionEx signale le système d’exploitation sélectionné pour de compatibilité des applications.
Exemples
Lorsque vous utilisez la fonction GetVersionEx pour déterminer si votre application s’exécute sur une version particulière du système d’exploitation, recherchez les numéros de version supérieurs ou égaux aux numéros de version souhaités. Cela garantit que le test réussit pour les versions ultérieures du système d’exploitation. Par exemple, si votre application nécessite Windows XP ou une version ultérieure, utilisez le test suivant.
#include <windows.h>
#include <stdio.h>
void main()
{
OSVERSIONINFO osvi;
BOOL bIsWindowsXPorLater;
ZeroMemory(&osvi, sizeof(OSVERSIONINFO));
osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
GetVersionEx(&osvi);
bIsWindowsXPorLater =
( (osvi.dwMajorVersion > 5) ||
( (osvi.dwMajorVersion == 5) && (osvi.dwMinorVersion >= 1) ));
if(bIsWindowsXPorLater)
printf("The system meets the requirements.\n");
else printf("The system does not meet the requirements.\n");
}
Pour obtenir un exemple qui identifie le système d’exploitation actuel, consultez Obtention de la version du système.
Note
L’en-tête sysinfoapi.h définit GetVersionEx comme alias qui sélectionne automatiquement la version ANSI ou Unicode de cette fonction en fonction de la définition de la constante de préprocesseur UNICODE. Le mélange de l’utilisation de l’alias neutre en encodage avec du code qui n’est pas neutre en encodage peut entraîner des incompatibilités qui entraînent des erreurs de compilation ou d’exécution. Pour plus d’informations, consultez Conventions pour les prototypes de fonction.
Exigences
Exigence | Valeur |
---|---|
client minimum pris en charge | Windows 2000 Professionnel [applications de bureau | Applications UWP] |
serveur minimum pris en charge | Windows 2000 Server [applications de bureau | Applications UWP] |
plateforme cible | Windows |
d’en-tête | sysinfoapi.h (include Windows.h) |
bibliothèque | Kernel32.lib |
DLL | Kernel32.dll |
Voir aussi
version du système d’exploitation