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.
ОШИБКИ
Кроме обычных могут возникать:
- EILSEQ
- Данные, полученные из входного потока, не содержат корректного символа.
АТРИБУТЫ
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
fgetwc(), getwc() | Безвредность в нитях | MT-Safe |
СТАНДАРТЫ
C11, POSIX.1-2008.
ИСТОРИЯ
POSIX.1-2001, C99.
ПРИМЕЧАНИЯ
Поведение fgetwc() зависит от категории LC_CTYPE текущей локали.
Из-за отсутствия дополнительной информации, передаваемой в fopen(3), закономерно ожидать, что fgetwc() на самом деле читает многобайтовую последовательность из потока, а затем преобразует её в широкий символ.
СМОТРИТЕ ТАКЖЕ
ПЕРЕВОД
Русский перевод этой страницы руководства разработал Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitry Bolkhovskikh <d20052005@yandex.ru>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>
Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ.
Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику по его адресу электронной почты или по адресу списка рассылки русских переводчиков.
2 мая 2024 г. | Linux man-pages 6.8 |