Sdílet prostřednictvím


_atodbl, _atodbl_l, _atoldbl, _atoldbl_l, _atoflt _atoflt_l

Převede řetězec na hodnotu double (_atodbl), long double (_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,
   const char * str
);
int _atoflt_l(
   _CRT_FLOAT * value,
   const char * str,
   locale_t locale
);

Parametry

  • value
    Hodnota double, long double nebo float, která jsou vytvořena převodem řetězce na hodnotu s plovoucí desetinnou čárkou.Tyto hodnoty jsou zabaleny ve struktuře.

  • str
    Řetězec, který se má analyzovat pro převod na hodnotu s plovoucí desetinnou čárkou.

  • locale
    Použité národní prostředí.

Vrácená hodnota

Pokud je úspěšná, vrátí hodnotu 0.Možné kódy chyb jsou _UNDERFLOW nebo _OVERFLOW, které jsou definovány v souboru hlaviček Math.h.

Poznámky

Tyto funkce převádějí řetězec na hodnotu s plovoucí desetinnou čárkou.Rozdíl mezi těmito funkcemi a rodinou funkcí atof je, že tyto funkce negenerují kód s plovoucí desetinnou čárkou a nevyvolávají hardwarové výjimky.Chybové stavy jsou místo toho hlášeny jako kódy chyb.

Pokud řetězec nemá platný výklad jako hodnotu s plovoucí desetinnou čárkou, value je nastavena na nulu a vrácená hodnota je nula.

Verze těchto funkcí s příponou _l jsou stejné jako ty, které ji nemají, s tím rozdílem, že používají předaný parametr národního prostředí namísto aktuálního národního prostředí pro vlákno.

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;
}
  

Viz také

Referenční dokumentace

Převod dat

Podpora plovoucí desetinné čárky

Národní prostředí

atof, _atof_l, _wtof, _wtof_l