Scroll to navigation

UNLOCKED_STDIO(3) Manual del Programador de Linux UNLOCKED_STDIO(3)

NOMBRE

*_unlocked - funciones no bloqueantes de stdio

SINOPSIS

#include <stdio.h>

int getc_unlocked(FILE *stream);
int getchar_unlocked(void);
int putc_unlocked(int c, FILE *stream);
int putchar_unlocked(int c);

#define _BSD_SOURCE /* or _SVID_SOURCE or _GNU_SOURCE */
#include <stdio.h>

void clearerr_unlocked(FILE *stream);
int feof_unlocked(FILE *stream);
int ferror_unlocked(FILE *stream);
int fileno_unlocked(FILE *stream);
int fflush_unlocked(FILE *stream);
int fgetc_unlocked(FILE *stream);
int fputc_unlocked(int c, FILE *stream);
size_t fread_unlocked(void *ptr, size_t size, size_t n,
  FILE *stream);
size_t fwrite_unlocked(const void *ptr, size_t size, size_t n,
  FILE *stream);

#define _GNU_SOURCE
#include <stdio.h>

char *fgets_unlocked(char *s, int n, FILE *stream);
int fputs_unlocked(const char *s, FILE *stream);

#define _GNU_SOURCE
#include <wchar.h>

wint_t getwc_unlocked(FILE *stream);
wint_t getwchar_unlocked(void);
wint_t fgetwc_unlocked(FILE *stream);
wint_t fputwc_unlocked(wchar_t wc, FILE *stream);
wint_t putwc_unlocked(wchar_t wc, FILE *stream);
wint_t putwchar_unlocked(wchar_t wc);
wchar_t *fgetws_unlocked(wchar_t *ws, int n, FILE *stream);
int fputws_unlocked(const wchar_t *ws, FILE *stream);

DESCRIPCIÓN

Cada una de estas funciones tiene el mismo comportamiento que sus homólogas sin el sufijo `_unlocked', salvo que no emplean bloqueo (no establecen bloqueos por sí mismas, y no comprueban la presencia de bloqueos establecidos por otros) y, por lo tanto, no son seguras en un entorno con hilos. Véase flockfile(3).

CONFORME A

Las cuatro funciones getc_unlocked(), getchar_unlocked(), putc_unlocked(), putchar_unlocked() están especificadas en POSIX.1. Las variantes no estándar de *_unlocked() están presentes en unos pocos sistemas Unix, y están desponibles en versiones recientes de glibc. No deberían ser utilizadas.

VÉASE TAMBIÉN

flockfile(3)
18 octubre 2001