_atodbl, _atodbl_l, _atoldbl, _atoldbl_l, _atoflt _atoflt_l
Převede řetězec na dvojitou (_atodbl), dvojité (_atoldbl), nebo float (_atoflt).
int _atodbl(
_CRT_DOUBLE * value,
char * str
);
int _atodbl_l (
_CRT_DOUBLE * value,
char * str,
locale_t locale
);
int _atoldbl(
_LDOUBLE * value,
char * str
);
int _atoldbl_l (
_LDOUBLE * value,
char * str,
locale_t locale
);
int _atoflt(
_CRT_FLOAT * value,
char * str
);
int _atoflt_l(
_CRT_FLOAT * value,
char * str,
locale_t locale
);
Parametry
value
Double, double dlouhé nebo plovoucí hodnotu vyrobených převedení řetězce na hodnotu s plovoucí desetinnou čárkou.Tyto hodnoty jsou zabaleny ve struktuře.str
Řetězec analyzovat převést hodnotu s plovoucí desetinnou čárkou.locale
Národní prostředí použít.
Vrácená hodnota
Vrátí 0, pokud je úspěšná. kódy chyb jsou _UNDERFLOW nebo _OVERFLOW, definované v záhlaví souboru Math.h.
Poznámky
Tyto funkce převést řetězec na hodnotu s plovoucí desetinnou čárkou.Rozdíl mezi tyto funkce a atof řady funkcí je, že tyto funkce generovat kód s plovoucí desetinnou čárkou a tudíž není výsledkem hardwarové výjimky.Místo toho chybové podmínky jsou hlášeny jako kód chyby.
Pokud řetězec nemá platný výklad jako hodnotu s plovoucí desetinnou čárkou, value je nastavena na nulu a návrat je hodnota nula.
Verze těchto funkcí se _l přípony jsou shodné s výjimkou, že používají národní prostředí parametr předaný namísto aktuální podproces národní prostředí.
Požadavky
Rutiny |
Požadované záhlaví |
---|---|
_atodbl, _atoldbl, _atoflt _atodbl_l, _atoldbl_l, _atoflt_l |
<stdlib.h> |
Příklad
// crt_atodbl.c
// Uses _atodbl to convert a string to a double precision
// floating point value.
#include <stdlib.h>
#include <stdio.h>
int main()
{
char str1[256] = "3.141592654";
char abc[256] = "abc";
char oflow[256] = "1.0E+5000";
_CRT_DOUBLE dblval;
_CRT_FLOAT fltval;
int retval;
retval = _atodbl(&dblval, str1);
printf("Double value: %lf\n", dblval.x);
printf("Return value: %d\n\n", retval);
retval = _atoflt(&fltval, str1);
printf("Float value: %f\n", fltval.f);
printf("Return value: %d\n\n", retval);
// A non-floating point value: returns 0.
retval = _atoflt(&fltval, abc);
printf("Float value: %f\n", fltval.f);
printf("Return value: %d\n\n", retval);
// Overflow.
retval = _atoflt(&fltval, oflow);
printf("Float value: %f\n", fltval.f);
printf("Return value: %d\n\n", retval);
return 0;
}