|
|
#include <stdio.h>int getc (stream) FILE *stream;
int getchar ()
int fgetc (stream) FILE *stream;
int getw (stream) FILE *stream;
The getc function returns the next character (that is, the next byte) from the named input stream, as an integer. It also moves the file pointer, if defined, ahead one character in stream. getchar is defined as getc(stdin). getc and getchar are macros.
The fgetc function behaves like getc, but is a function rather than a macro. fgetc runs more slowly than getc, but it takes less space per invocation and its name can be passed as an argument to a function.
The getw function returns the next word (that is, the next integer) from the named input stream. getw increments the associated file pointer, if defined, to point to the next word. The size of a word is the size of an integer and varies from machine to machine. getw assumes no special alignment in the file.
Under the following conditions, the functions getc(), getchar(), fgetc() and getw() fail and set errno to:
The fgetc() function may fail if:
f++)
does not work well.
fgetc should be used instead.
Because of possible differences in word length and byte ordering,
files written using putw are machine-dependent,
and may not be read using getw
on a different processor.
readn (p, cnt)
char p[ ];
int cnt;
{
int i,c;
i = 0;
while ( i<cnt )
if (( p[i++] = getchar()) == EOF ) {
p[i] = 0;
return(EOF);
}
return(0);
}
Note that if getchar
is reading from the keyboard, it waits for characters
to be entered before returning.
X/Open Portability Guide, Issue 3, 1989
;
ANSI X3.159-1989 Programming Language -- C
;
Intel386 Binary Compatibility Specification, Edition 2 (iBCSe2)
;
IEEE POSIX Std 1003.1-1990 System Application Program Interface (API) [C Language] (ISO/IEC 9945-1)
;
and
NIST FIPS 151-1
.
getw is conformant with:
Intel386 Binary Compatibility Specification, Edition 2 (iBCSe2)
;
and
X/Open Portability Guide, Issue 3, 1989
.