Scroll to navigation

fgetwc(3) Library Functions Manual fgetwc(3)

ИМЯ

fgetwc, getwc - считывает широкий символ из потока FILE

LIBRARY

Standard C library (libc, -lc)

СИНТАКСИС

#include <stdio.h>
#include <wchar.h>
wint_t fgetwc(FILE *stream);
wint_t getwc(FILE *stream);

ОПИСАНИЕ

Функция fgetwc() — это эквивалент функции fgetc(3), но для широких символов. Она читает широкий символ из stream и возвращает его. Если достигнут конец потока или значение ferror(stream) истинно, то функция возвращает WEOF. Если при преобразовании в широкий символ возникает ошибка, то значение переменной errno устанавливается равным EILSEQ и возвращается WEOF.

Функция getwc() — это функция, или макрос, идентичный fgetwc(). Она может быть реализована в виде макроса, и может вычислять свой аргумент более одного раза. Вообще нет смысла использовать эту функцию.

Для неблокирующих аналогов, см. unlocked_stdio(3).

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

On success, fgetwc() returns the next wide-character from the stream. Otherwise, WEOF is returned, and errno is set to indicate the error.

ОШИБКИ

Кроме обычных могут возникать:

Данные, полученные из входного потока, не содержат корректного символа.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).

Интерфейс Атрибут Значение
fgetwc(), getwc() Безвредность в нитях MT-Safe

СТАНДАРТЫ

POSIX.1-2001, POSIX.1-2008, C99.

ЗАМЕЧАНИЯ

Поведение fgetwc() зависит от категории LC_CTYPE текущей локали.

Из-за отсутствия дополнительной информации, передаваемой в fopen(3), закономерно ожидать, что fgetwc() на самом деле читает многобайтовую последовательность из потока, а затем преобразует её в широкий символ.

СМ. ТАКЖЕ

fgetws(3), fputwc(3), ungetwc(3), unlocked_stdio(3)

ПЕРЕВОД

Русский перевод этой страницы руководства был сделан Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitry Bolkhovskikh <d20052005@yandex.ru>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>

Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.

Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на man-pages-ru-talks@lists.sourceforge.net.

15 декабря 2022 г. Linux man-pages 6.03