Sdílet prostřednictvím


fscanf_s, _fscanf_s_l, fwscanf_s, _fwscanf_s_l

Čte formátovaná data ze streamu. Tyto verze fscanf, , _fscanf_l_fwscanf_lfwscanfmají vylepšení zabezpečení, jak je popsáno v funkcích zabezpečení v CRT.

Syntaxe

int fscanf_s(
   FILE *stream,
   const char *format [,
   argument ]...
);
int _fscanf_s_l(
   FILE *stream,
   const char *format,
   _locale_t locale [,
   argument ]...
);
int fwscanf_s(
   FILE *stream,
   const wchar_t *format [,
   argument ]...
);
int _fwscanf_s_l(
   FILE *stream,
   const wchar_t *format,
   _locale_t locale [,
   argument ]...
);

Parametry

stream
Ukazatel na FILE strukturu.

format
Řetězec řízení formátu

argument
Volitelné argumenty

locale
Národní prostředí, které se má použít

Vrácená hodnota

Každá z těchto funkcí vrátí počet polí, která úspěšně převede a přiřadí. Vrácená hodnota neobsahuje pole, která byla přečtená, ale nepřiřazená. Vrácená hodnota 0 označuje, že nebyla přiřazena žádná pole. Pokud dojde k chybě nebo pokud je dosaženo konce datového proudu souboru před prvním převodem, návratová hodnota je EOF pro fscanf_s a fwscanf_s.

Tyto funkce ověřují své parametry. Pokud stream je neplatný ukazatel souboru nebo format je ukazatel null, tyto funkce vyvolávají neplatnou obslužnou rutinu parametru, jak je popsáno v ověření parametru. Pokud provádění může pokračovat, tyto funkce se vrátí EOF a nastaví errno na EINVAL.

Poznámky

Funkce fscanf_s čte data z aktuální pozice stream do umístění, která argument jsou daná (pokud existuje). Každý argument musí být ukazatel na proměnnou typu, která odpovídá specifikátoru typu v format. formatřídí interpretaci vstupních polí a má stejný tvar a funkci jako format argument pro scanf_s; viz Pole specifikace formátu: scanf a wscanf funkce popis .format fwscanf_s je verze širokého znaku fscanf_s; argument formátu je fwscanf_s řetězec širokého znaku. Tyto funkce se chovají stejně, pokud je datový proud otevřen v režimu ANSI. fscanf_s v současné době nepodporuje vstup z datového proudu UNICODE.

Hlavní rozdíl mezi bezpečnějšími funkcemi (které mají příponu_s) a dalšími verzemi spočívá v tom, že bezpečnější funkce vyžadují velikost znaků každého c, C, , , sa S[ pole typu, které mají být předány jako argument bezprostředně za proměnnou. Další informace naleznete v tématu scanf_s, _scanf_s_l, wscanf_s_wscanf_s_l a scanf specifikace šířky.

Poznámka

Parametr velikosti je typu unsigned, nikoli size_t.

Verze těchto funkcí, které mají příponu _l , jsou shodné s tím rozdílem, že používají parametr národního prostředí předaný místo aktuálního národního prostředí vlákna.

Mapování rutin obecného textu

TCHAR.H Rutinní _UNICODE a _MBCS není definován _MBCS Definovány _UNICODE Definovány
_ftscanf_s fscanf_s fscanf_s fwscanf_s
_ftscanf_s_l _fscanf_s_l _fscanf_s_l _fwscanf_s_l

Požadavky

Function Požadovaný hlavičkový soubor
fscanf_s, _fscanf_s_l <stdio.h>
fwscanf_s, _fwscanf_s_l <stdio.h> nebo <wchar.h>

Další informace o kompatibilitě najdete v tématu Kompatibilita.

Příklad

// crt_fscanf_s.c
// This program writes formatted
// data to a file. It then uses fscanf to
// read the various data back from the file.

#include <stdio.h>
#include <stdlib.h>

FILE *stream;

int main( void )
{
   long l;
   float fp;
   char s[81];
   char c;

   errno_t err = fopen_s( &stream, "fscanf.out", "w+" );
   if( err )
      printf_s( "The file fscanf.out was not opened\n" );
   else
   {
      fprintf_s( stream, "%s %ld %f%c", "a-string",
               65000, 3.14159, 'x' );
      // Set pointer to beginning of file:
      fseek( stream, 0L, SEEK_SET );

      // Read data back from file:
      fscanf_s( stream, "%s", s, _countof(s) );
      fscanf_s( stream, "%ld", &l );

      fscanf_s( stream, "%f", &fp );
      fscanf_s( stream, "%c", &c, 1 );

      // Output data read:
      printf( "%s\n", s );
      printf( "%ld\n", l );
      printf( "%f\n", fp );
      printf( "%c\n", c );

      fclose( stream );
   }
}
a-string
65000
3.141590
x

Viz také

Vstupně-výstupní operace streamu
_cscanf_s, _cscanf_s_l, _cwscanf_s, _cwscanf_s_l
fprintf_s, _fprintf_s_l, fwprintf_s, _fwprintf_s_l
scanf_s, _scanf_s_l, wscanf_s, _wscanf_s_l
sscanf_s, _sscanf_s_l, swscanf_s, _swscanf_s_l
fscanf, _fscanf_l, fwscanf, _fwscanf_l