| wcsrtombs(3) | Library Functions Manual | wcsrtombs(3) |
НАИМЕНОВАНИЕ¶
wcsrtombs - преобразует широкосимвольную строку в многобайтовую строку
БИБЛИОТЕКА¶
Стандартная библиотека языка C (libc, -lc)
ОБЗОР¶
#include <wchar.h>
size_t wcsrtombs(size_t size;
char dest[restrict size], const wchar_t **restrict src,
size_t size, mbstate_t *restrict ps);
ОПИСАНИЕ¶
If dest is not NULL, the wcsrtombs() function converts the wide-character string *src to a multibyte string starting at dest. At most size bytes are written to dest. The shift state *ps is updated. The conversion is effectively performed by repeatedly calling wcrtomb(dest, *src, ps), as long as this call succeeds, and then incrementing dest by the number of bytes written and *src by one. The conversion can stop for three reasons:
- •
- Встретившийся широкий символ нельзя представить в виде многобайтовой последовательности (в соответствии с текущей системной локалью). В этом случае *src будет указывать на неправильный широкий символ, возвращается (size_t) -1, а значение errno становится равным EILSEQ.
- •
- The size limit forces a stop. In this case, *src is left pointing to the next wide character to be converted, and the number of bytes written to dest is returned.
- •
- The wide-character string has been completely converted, including the terminating null wide character (L'\0'), which has the side effect of bringing back *ps to the initial state. In this case, *src is set to NULL, and the number of bytes written to dest, excluding the terminating null byte ('\0'), is returned.
If dest is NULL, size is ignored, and the conversion proceeds as above, except that the converted bytes are not written out to memory, and that no size limit exists.
В обоих перечисленных случаях, если ps равно NULL, то используется статическое анонимное состояние, известное только функции wcsrtombs().
The programmer must ensure that there is room for at least size bytes at dest.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
Функция wcsrtombs() возвращает количество байт в полученной многобайтовой последовательности, не включая завершающий байт null. Если встречается широкий символ, который невозможно преобразовать, возвращается (size_t) -1 и значение errno становится равным EILSEQ.
АТРИБУТЫ¶
Описание терминов данного раздела смотрите в attributes(7).
| Интерфейс | Атрибут | Значение |
| wcsrtombs() | Безвредность в нитях | MT-Unsafe race:wcsrtombs/!ps |
СТАНДАРТЫ¶
C11, POSIX.1-2008.
ИСТОРИЯ¶
POSIX.1-2001, C99.
ПРИМЕЧАНИЯ¶
Поведение wcsrtombs() зависит от категории LC_CTYPE текущей локали.
Передавать NULL в качестве ps небезопасно при работе с нитями.
СМОТРИТЕ ТАКЖЕ¶
iconv(3), mbsinit(3), wcrtomb(3), wcsnrtombs(3), wcstombs(3)
ПЕРЕВОД¶
Русский перевод этой страницы руководства разработал(и) Azamat Hackimov <azamat.hackimov@gmail.com>, Yuri Kozlov <yuray@komyakino.ru> и Kirill Rekhov <krekhov.dev@gmail.com>
Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ.
Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику(ам) по его(их) адресу(ам) электронной почты или по адресу списка рассылки русских переводчиков.
| 28 июня 2025 г. | Справочные страницы Linux (невыпущенные) |