Partage via


_strtoi64, , _wcstoi64_strtoi64_l, ,_wcstoi64_l

Convertissent une chaîne en valeur __int64.

Syntaxe

__int64 _strtoi64(
   const char *strSource,
   char **endptr,
   int base
);
__int64 _wcstoi64(
   const wchar_t *strSource,
   wchar_t **endptr,
   int base
);
__int64 _strtoi64_l(
   const char *strSource,
   char **endptr,
   int base,
   _locale_t locale
);
__int64 _wcstoi64_l(
   const wchar_t *strSource,
   wchar_t **endptr,
   int base,
   _locale_t locale
);

Paramètres

strSource
Chaîne se terminant par un caractère Null à convertir.

endptr
Pointeur désignant le caractère qui arrête l’analyse.

base
Base numérique à utiliser.

locale
Paramètres régionaux à utiliser.

Valeur retournée

La fonction _strtoi64 retourne la valeur représentée dans la chaîne strSource, sauf dans le cas où la représentation entraînerait un dépassement de capacité positif, auquel cas elle retourne _I64_MAX ou _I64_MIN. La fonction retourne 0 si aucune conversion ne peut être effectuée. _wcstoi64 retourne des valeurs de façon analogue à _strtoi64.

_I64_MAX et _I64_MIN sont définis dans LIMITS.H.

Si strSource a la valeur NULL ou que base est différent de zéro et inférieur à 2 ou supérieur à 36, errno prend la valeur EINVAL.

Pour plus d’informations sur les codes de retour, consultez , , _sys_errlist_doserrnoet _sys_nerr.errno

Notes

La fonction _strtoi64 convertit strSource en __int64. Les deux fonctions arrêtent de lire la chaîne strSource au premier caractère qu’elles ne peuvent pas reconnaître dans le cadre d’un nombre. Il peut s’agir du caractère null de fin, ou il peut s’agir du premier caractère numérique supérieur ou égal à base. _wcstoi64 est une version à caractères larges de _strtoi64 ; son argument strSource est une chaîne de caractères larges. Ces fonctions se comportent sinon de façon identique.

Par défaut, l’état global de cette fonction est limité à l’application. Pour le modifier, consultez l’état global dans le CRT.

Mappages de routines de texte générique

Routine TCHAR.H _UNICODE et _MBCS non définis _MBCS défini _UNICODE défini
_tcstoi64 _strtoi64 _strtoi64 _wcstoi64
_tcstoi64_l _strtoi64_l _strtoi64_l _wcstoi64_l

Le paramètre de catégorie des LC_NUMERIC paramètres régionaux détermine la reconnaissance du caractère radix dans strSource; pour plus d’informations, consultez setlocale. Les fonctions sans _l suffixe utilisent les paramètres régionaux actuels ; _strtoi64_l elles _wcstoi64_l sont identiques à la fonction correspondante sans le suffixe, sauf qu’elles utilisent les paramètres régionaux passés à la _l place. Pour plus d’informations, consultez Locale.

Si endptr ce n’est pas NULLle cas, un pointeur vers le caractère qui a arrêté l’analyse est stocké à l’emplacement vers lequel pointe endptr. Si aucune conversion ne peut être effectuée (aucun chiffre valide n’a été trouvé ou la base spécifiée n’est pas valide), la valeur de strSource est stockée à l’emplacement désigné par endptr.

_strtoi64 s’attend à ce que strSource pointe vers une chaîne au format suivant :

[whitespace] [{+ | -}] [0 [{ x | X }]] [] []digits | letters

Un whitespace espace et des tabulations peuvent être ignorés. digits sont un ou plusieurs chiffres décimaux. letters sont une ou plusieurs des lettres 'a' à 'z' (ou 'A' à 'Z'). Le premier caractère qui ne correspond pas à ce formulaire arrête l’analyse. Si base la valeur est comprise entre 2 et 36, elle est utilisée comme base du nombre. Si base a la valeur 0, les premiers caractères de la chaîne désignée par strSource servent à déterminer la base. Si le premier caractère est « 0 » et que le deuxième caractère n’est pas « x » ou « X », la chaîne est interprétée comme un entier octal. Si le premier caractère est « 0 » et que le deuxième est « x » ou « X », la chaîne est interprétée comme étant un entier hexadécimal. Si le premier caractère est un chiffre compris entre « 1 » et « 9 », la chaîne est interprétée comme étant un entier décimal. Les lettres de « a » à « z » (ou de « A » à « Z ») se voient affecter des valeurs comprises entre 10 et 35 ; seules sont autorisées les lettres dont les valeurs affectées sont inférieures à base. Le premier caractère situé en dehors de la plage de la base a pour effet d’arrêter l’analyse. Par exemple, si base est égal à 0 et que le premier caractère analysé est « 0 », il est supposé qu’il s’agit d’un entier octal et un caractère « 8 » ou « 9 » a pour effet de stopper l’analyse.

Spécifications

Fonction En-tête requis
_strtoi64, _strtoi64_l <stdlib.h>
_wcstoi64, _wcstoi64_l <stdlib.h> ou <wchar.h>

Pour plus d’informations sur la compatibilité, consultez Compatibility.

Voir aussi

Conversion de données
Paramètres régionaux
localeconv
setlocale, _wsetlocale
Chaîne à fonctions de valeur numérique
strtod, , _strtod_lwcstod, ,_wcstod_l
strtoul, , _strtoul_lwcstoul, ,_wcstoul_l
atof, , _atof_l_wtof, ,_wtof_l