Node:Character Input,
Next:Line Input,
Previous:Simple Output,
Up:I/O on Streams
Character Input
This section describes functions for performing character-oriented
input.  These narrow streams functions are declared in the header file
stdio.h and the wide character functions are declared in
wchar.h.
These functions return an int or wint_t value (for narrow
and wide stream functions respectively) that is either a character of
input, or the special value EOF/WEOF (usually -1).  For
the narrow stream functions it is important to store the result of these
functions in a variable of type int instead of char, even
when you plan to use it only as a character.  Storing EOF in a
char variable truncates its value to the size of a character, so
that it is no longer distinguishable from the valid character
(char) -1.  So always use an int for the result of
getc and friends, and check for EOF after the call; once
you've verified that the result is not EOF, you can be sure that
it will fit in a char variable without loss of information.
| int fgetc (FILE *stream) | Function | 
| This function reads the next character as an unsigned charfrom
the stream stream and returns its value, converted to anint.  If an end-of-file condition or read error occurs,EOFis returned instead. | 
| wint_t fgetwc (FILE *stream) | Function | 
| This function reads the next wide character from the stream stream
and returns its value.  If an end-of-file condition or read error
occurs, WEOFis returned instead. | 
| int fgetc_unlocked (FILE *stream) | Function | 
| The fgetc_unlockedfunction is equivalent to thefgetcfunction except that it does not implicitly lock the stream. | 
| wint_t fgetwc_unlocked (FILE *stream) | Function | 
| The fgetwc_unlockedfunction is equivalent to thefgetwcfunction except that it does not implicitly lock the stream.This function is a GNU extension. 
 | 
| int getc (FILE *stream) | Function | 
| This is just like fgetc, except that it is permissible (and
typical) for it to be implemented as a macro that evaluates the
stream argument more than once.getcis often highly
optimized, so it is usually the best function to use to read a single
character. | 
| wint_t getwc (FILE *stream) | Function | 
| This is just like fgetwc, except that it is permissible for it to
be implemented as a macro that evaluates the stream argument more
than once.getwccan be highly optimized, so it is usually the
best function to use to read a single wide character. | 
| int getc_unlocked (FILE *stream) | Function | 
| The getc_unlockedfunction is equivalent to thegetcfunction except that it does not implicitly lock the stream. | 
| wint_t getwc_unlocked (FILE *stream) | Function | 
| The getwc_unlockedfunction is equivalent to thegetwcfunction except that it does not implicitly lock the stream.This function is a GNU extension. 
 | 
| int getchar (void) | Function | 
| The getcharfunction is equivalent togetcwithstdinas the value of the stream argument. | 
| wint_t getwchar (void) | Function | 
| The getwcharfunction is equivalent togetwcwithstdinas the value of the stream argument. | 
| int getchar_unlocked (void) | Function | 
| The getchar_unlockedfunction is equivalent to thegetcharfunction except that it does not implicitly lock the stream. | 
| wint_t getwchar_unlocked (void) | Function | 
| The getwchar_unlockedfunction is equivalent to thegetwcharfunction except that it does not implicitly lock the stream.This function is a GNU extension. 
 | 
Here is an example of a function that does input using fgetc.  It
would work just as well using getc instead, or using
getchar () instead of fgetc (stdin).  The code would
also work the same for the wide character stream functions.
int
y_or_n_p (const char *question)
{
  fputs (question, stdout);
  while (1)
    {
      int c, answer;
      /* Write a space to separate answer from question. */
      fputc (' ', stdout);
      /* Read the first character of the line.
         This should be the answer character, but might not be. */
      c = tolower (fgetc (stdin));
      answer = c;
      /* Discard rest of input line. */
      while (c != '\n' && c != EOF)
        c = fgetc (stdin);
      /* Obey the answer if it was valid. */
      if (answer == 'y')
        return 1;
      if (answer == 'n')
        return 0;
      /* Answer was invalid: ask for valid answer. */
      fputs ("Please answer y or n:", stdout);
    }
}
| int getw (FILE *stream) | Function | 
| This function reads a word (that is, an int) from stream. 
It's provided for compatibility with SVID.  We recommend you usefreadinstead (see Block Input/Output).  Unlikegetc,
anyintvalue could be a valid result.getwreturnsEOFwhen it encounters end-of-file or an error, but there is no
way to distinguish this from an input word with value -1. |