Stream I/O: See Also
Stream I/O: See Also
Stream I/O: See Also
Stream I/O
See Also
Input and Output | Run-Time Routines by Category | Run-Time Routines and .NET
Framework Equivalents
These functions process data in different sizes and formats, from single characters to
large data structures. They also provide buffering, which can improve performance. The
default size of a stream buffer is 4K. These routines affect only buffers created by the
run-time library routines, and have no effect on buffers created by the operating system.
Routine Use
clearerr Clear error indicator for stream
fclose Close stream
_fcloseall Close all open streams except stdin, stdout, and stderr
_fdopen, Associate stream with file descriptor of open file
wfdopen
feof Test for end of file on stream
ferror Test for error on stream
fflush Flush stream to buffer or storage device
fgetc, fgetwc Read character from stream (function versions of getc and getwc)
_fgetchar, Read character from stdin (function versions of getchar and
_fgetwchar getwchar)
fgetpos Get position indicator of stream
fgets, fgetws Read string from stream
_fileno Get file descriptor associated with stream
_flushall Flush all streams to buffer or storage device
fopen, _wfopen Open stream
fprintf, fwprintf Write formatted data to stream
fputc, fputwc Write a character to a stream (function versions of putc and putwc)
_fputchar, Write character to stdout (function versions of putchar and putwchar)
_fputwchar
fputs, fputws Write string to stream
fread Read unformatted data from stream
freopen, Reassign FILE stream pointer to new file or device
_wfreopen
fscanf, fwscanf Read formatted data from stream
fseek Move file position to given location
fsetpos Set position indicator of stream
_fsopen, Open stream with file sharing
_wfsopen
ftell Get current file position
fwrite Write unformatted data items to stream
getc, getwc Read character from stream (macro versions of fgetc and fgetwc)
getchar, getwchar Read character from stdin (macro versions of fgetchar and fgetwchar)
_getmaxstdio Returns the number of simultaneously open files permitted at the
stream I/O level.
gets, getws Read line from stdin
_getw Read binary int from stream
printf, wprintf Write formatted data to stdout
putc, putwc Write character to a stream (macro versions of fputc and fputwc)
putchar, Write character to stdout (macro versions of fputchar and fputwchar)
putwchar
puts, _putws Write line to stream
_putw Write binary int to stream
rewind Move file position to beginning of stream
_rmtmp Remove temporary files created by tmpfile
scanf, wscanf Read formatted data from stdin
setbuf Control stream buffering
_setmaxstdio Set a maximum for the number of simultaneously open files at the
stream I/O level.
setvbuf Control stream buffering and buffer size
_snprintf, Write formatted data of specified length to string
_snwprintf
_snscanf, Read formatted data of a specified length from the standard input
_snwscanf stream.
sprintf, swprintf Write formatted data to string
sscanf, swscanf Read formatted data from string
_tempnam, Generate temporary filename in given directory
_wtempnam
tmpfile Create temporary file
tmpnam, Generate temporary filename
_wtmpnam
ungetc, ungetwc Push character back onto stream
vfprintf, Write formatted data to stream
vfwprintf
vprintf, vwprintf Write formatted data to stdout
_vsnprintf, Write formatted data of specified length to buffer
_vsnwprintf
vsprintf, Write formatted data to buffer
vswprintf
When a program begins execution, the startup code automatically opens several streams:
standard input (pointed to by stdin), standard output (pointed to by stdout), and standard
error (pointed to by stderr). These streams are directed to the console (keyboard and
screen) by default. Use freopen to redirect stdin, stdout, or stderr to a disk file or a
device.
Files opened using the stream routines are buffered by default. The stdout and stderr
functions are flushed whenever they are full or, if you are writing to a character device,
after each library call. If a program terminates abnormally, output buffers may not be
flushed, resulting in loss of data. Use fflush or _flushall to ensure that the buffer
associated with a specified file or all open buffers are flushed to the operating system,
which can cache data before writing it to disk. The commit-to-disk feature ensures that
the flushed buffer contents are not lost in the event of a system failure.
Link with the file COMMODE.OBJ to set a global commit flag. The default
setting of the global flag is n, for "no-commit."
Set the mode flag to c with fopen or _fdopen.
Any file specifically opened with either the c or the n flag behaves according to the flag,
regardless of the state of the global commit/no-commit flag.
If your program does not explicitly close a stream, the stream is automatically closed
when the program terminates. However, you should close a stream when your program
finishes with it, as the number of streams that can be open at one time is limited. See
_setmaxstdio for information on this limit.
Input can follow output directly only with an intervening call to fflush or to a file-
positioning function (fseek, fsetpos, or rewind). Output can follow input without an
intervening call to a file-positioning function if the input operation encounters the end of
the file.
See Also
Input and Output | Run-Time Routines by Category | Run-Time Routines and .NET
Framework Equivalents