fscanf_s, _fscanf_s_l, fwscanf_s, _fwscanf_s_l

Čte formátovaná data ze streamu. Tyto verze ,fscanf_fscanf_l , fwscanf_fwscanf_l mají vylepšení zabezpečení, jak je popsáno v tématu Funkce 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 nezahrnuje pole, která byla přečtená, ale nebyla přiřazena. Návratová hodnota 0 označuje, že nebyla přiřazena žádná pole. Pokud dojde k chybě nebo pokud je konec datového proudu souboru dosažen 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 na soubor nebo format je ukazatel null, tyto funkce vyvolají neplatnou obslužnou rutinu parametru, jak je popsáno v části Ověření parametru. Pokud je povoleno pokračovat v provádění, vrátí EOF se tyto funkce a nastaví errno se na EINVAL.

Poznámky

Funkce fscanf_s načítá data z aktuální pozice stream do umístění, která jsou daná argument (pokud existují). Každý z nich argument musí být ukazatelem 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 Formát polí specifikace: scanf a wscanf funkce popis .format fwscanf_s je širokoúhlá verze souboru fscanf_s; argumentem fwscanf_s pro formát je řetězec s širokým znakem. 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 ostatními verzemi spočívá v tom, že bezpečnější funkce vyžadují velikost znaků každého cpole , C, s, Sa [ typu, které mají být předány jako argument bezprostředně za proměnnou. Další informace najdete v tématech scanf_s, _scanf_s_l, _wscanf_s_lwscanf_s a scanf Specifikace šířky.

Poznámka

Parametr size je typu unsigned, nikoli size_t.

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

Mapování rutin obecného textu

TCHAR.H Rutinní _UNICODE a _MBCS není definováno _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

Funkce 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é

I/O proudu
_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