PUTC(3S) PUTC(3S)
putc, putchar, fputc, putw, putc_unlocked, putchar_unlocked - put
character or word on a stream
#include <stdio.h>
int putc (int c, FILE *stream);
int putchar (int c);
int fputc (int c, FILE *stream);
int putw (int w, FILE *stream);
int putc_unlocked (int c, FILE *stream);
int putchar_unlocked (int c);
Fputc and putc write the character c onto the output stream indicated
by stream at the position indicated by the associated file pointer (if
defined), advancing this pointer to the next character position. For
files which cannot be positioned, or which have been opened in append
mode (see fopen(3s)), the character is appended to the output stream.
putchar(c) is defined as putc(c, stdout). Each of these functions is
available in the C library. In addition, putc and putchar are macros
defined in <stdio.h>. (see below under CAVEATS for important details on
the implementation of these macros.)
The function versions of putc and putchar, as well as fputc runs more
slowly than the corresponding macros, but they take less space per
invocation and the function name can be passed as an argument to another
function.
putw writes the word (i.e. integer) w to the output stream (at the
position at which the file pointer, if defined, is pointing). The size
of a word is the size of an integer and varies from machine to machine.
putw neither assumes nor causes special alignment in the file.
The putc_unlocked and putchar_unlocked functions are equivalent to the
putc and putchar functions, respectively. However, these functions are
not thread-safe and thus must only be called under the protection of the
flockfile (or ftrylockfile) and funlockfile functions.
fclose(3S), ferror(3S), fopen(3S), fread(3S), printf(3S), puts(3S),
setbuf(3S), stdio(3S).
Page 1
PUTC(3S) PUTC(3S)
DIAGNOSTICS
On success, putc, putchar, and fputc each return the value they have
written. On failure, they return the constant EOF. This will occur if
the stream cannot be written for some reason, such as it is not open for
writing or if the output file cannot be extended.
Putw returns the value of ferror(stream), which is non-zero if an error
occurred on stream.
When using the macro versions of putc and putchar, the stream argument
may be evaluated more than once. Thus, it must not be an expression with
side-effects. In particular, putc(c,*f++) does not work sensibly. In
these situations, the macro must either be #undef'd, or fputc 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.
When using the macros for putc and putchar, hidden external names may be
referenced. Although these names are prefixed with an underscore, they
may conflict with names which the ANSI C Standard reserves for the user
when appearing in a local context. It is thus recommended that users of
these macros reserve all names which begin with an underscore for the
implementation, and avoid defining such names, even in a local context.
PPPPaaaaggggeeee 2222 [ Back ]
|