MBSNRTOWCS(3) | Руководство программиста Linux | MBSNRTOWCS(3) |
mbsnrtowcs - преобразует многобайтовую строку в строку широких символов
#include <wchar.h>
size_t mbsnrtowcs(wchar_t *dest, const char **src, size_t nms, size_t len, mbstate_t *ps);
Требования макроса тестирования свойств для glibc (смотрите feature_test_macros(7)):
mbsnrtowcs():
Функция mbsnrtowcs() похожа на функцию mbsrtowcs(3), исключая то, что количество преобразуемых байт, начиная с *src, ограничено nms байтами.
Если dest не равно NULL, то функция mbsnrtowcs() преобразует не более nms байт многобайтовой строки *src в строку широких символов, начинающуюся с dest. В dest будет записано не более len символов. Обновляется состояние сдвига *ps. Эффективное выполнение преобразования осуществляется повторяющимися вызовами mbrtowc(dest, *src, n, ps), где n — некое положительное число, и пока вызов завершается успешно, увеличивая dest на единицу и *src на количество использованных байт. Преобразование может остановиться по трём причинам:
Если входной буфер заканчивается неполным символом, в POSIX.1 не указано где остановится преобразование — в конце предыдущего символа (если есть) или в конце входного буфера. В реализации glibc принят первый вариант.
Если значение dest равно NULL, то len игнорируется и преобразование выполняется как описано выше, исключая то, что преобразованные широкие символы не записываются в память и нет ограничения на длину строки назначения.
В обоих перечисленных случаях, если ps равно NULL, то используется статическое анонимное состояние, известное только функции mbsnrtowcs().
Программист должен проверить, что в dest есть место по крайней мере для len широких символов.
Функция mbsnrtowcs() возвращает количество широких символов, которые составили преобразованную часть широкосимвольной строки, не включая конечный широкий символ null. Если обнаружена некорректная многобайтовая последовательность, то возвращается (size_t) -1, а errno присваивается EILSEQ.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
mbsnrtowcs() | Безвредность в нитях | MT-Unsafe race:mbsnrtowcs/!ps |
POSIX.1-2008.
Поведение mbsnrtowcs() зависит от категории LC_CTYPE текущей локали.
Передавать NULL в качестве ps небезопасно при работе с нитями.
2019-03-06 | GNU |