.\" -*- coding: UTF-8 -*- '\" t .\" Copyright 1993 David Metcalfe (david@prism.demon.co.uk) .\" and Copyright (c) 2008 Linux Foundation, written by Michael Kerrisk .\" .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\" Modified Mon Apr 12 12:49:57 1993, David Metcalfe .\" Modified Sat Jul 24 18:56:22 1993, Rik Faith (faith@cs.unc.edu) .\" Modified Wed Feb 20 21:09:36 2002, Ian Redfern (redferni@logica.com) .\" 2008-07-09, mtk, add rawmemchr() .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH memchr 3 "15 декабря 2022 г." "Linux man\-pages 6.02" .SH ИМЯ memchr, memrchr, rawmemchr \- выполняют поиск символа в памяти .SH LIBRARY Standard C library (\fIlibc\fP, \fI\-lc\fP) .SH СИНТАКСИС .nf \fB#include \fP .PP \fBvoid *memchr(const void \fP\fIs\fP\fB[.\fP\fIn\fP\fB], int \fP\fIc\fP\fB, size_t \fP\fIn\fP\fB);\fP \fBvoid *memrchr(const void \fP\fIs\fP\fB[.\fP\fIn\fP\fB], int \fP\fIc\fP\fB, size_t \fP\fIn\fP\fB);\fP \fBvoid *rawmemchr(const void \fP\fIs\fP\fB[.\fP\fIn\fP\fB], int \fP\fIc\fP\fB);\fP .fi .PP .RS -4 Требования макроса тестирования свойств для glibc (см. \fBfeature_test_macros\fP(7)): .RE .PP \fBmemrchr\fP(), \fBrawmemchr\fP(): .nf _GNU_SOURCE .fi .SH ОПИСАНИЕ Функция \fBmemchr\fP() сканирует первые \fIn\fP байт участка памяти, указанного в \fIs\fP, в поисках экземпляра \fIc\fP. Считается, что байты в памяти, указанной \fIs\fP, и значение \fIc\fP имеют тип \fIunsigned char\fP. .PP Функция \fBmemrchr\fP() похожа на \fBmemchr\fP(), за исключением того, что она ищет в участке \fIn\fP байт, указанных в \fIs\fP, не сначала, а с конца. .PP Функция \fBrawmemchr\fP() похожа на \fBmemchr\fP(): она подразумевает (то есть программист в этом уверен), что экземпляр \fIc\fP точно находится где\-то в памяти начало которой указано \fIs\fP, и при это производит оптимизированный поиск символа \fIc\fP (то есть, не используется счётчик для ограничения диапазона поиска). Если экземпляр \fIc\fP не найден, то результат непредсказуем. Следующий вызов является примером быстрого поиска завершающего строку байта null: .PP .in +4n .EX char *p = rawmemchr(s,\ \(aq\e0\(aq); .EE .in .SH "ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ" Функции \fBmemchr\fP() и \fBmemrchr\fP() возвращают указатель на совпавший байт, либо NULL, если в указанном участке памяти искомого байта нет. .PP Функция \fBrawmemchr\fP() возвращает указатель на совпавший байт (если он был обнаружен). Если совпадений не найдено, результат не определён. .SH ВЕРСИИ \fBrawmemchr\fP() first appeared in glibc 2.1. .PP \fBmemrchr\fP() first appeared in glibc 2.2. .SH АТРИБУТЫ Описание терминов данного раздела смотрите в \fBattributes\fP(7). .ad l .nh .TS allbox; lbx lb lb l l l. Интерфейс Атрибут Значение T{ \fBmemchr\fP(), \fBmemrchr\fP(), \fBrawmemchr\fP() T} Безвредность в нитях MT\-Safe .TE .hy .ad .sp 1 .SH СТАНДАРТЫ \fBmemchr\fP(): POSIX.1\-2001, POSIX.1\-2008, C89, C99, SVr4, 4.3BSD. .PP Функция \fBmemrchr\fP() является расширением GNU, доступным в glibc начиная с версии 2.1.91. .PP Функция \fBrawmemchr\fP() является расширением GNU, доступным в glibc начиная с версии 2.1. .SH "СМ. ТАКЖЕ" \fBbstring\fP(3), \fBffs\fP(3), \fBindex\fP(3), \fBmemmem\fP(3), \fBrindex\fP(3), \fBstrchr\fP(3), \fBstrpbrk\fP(3), \fBstrrchr\fP(3), \fBstrsep\fP(3), \fBstrspn\fP(3), \fBstrstr\fP(3), \fBwmemchr\fP(3) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства был сделан aereiae , Alexey , Azamat Hackimov , Dmitriy S. Seregin , Dmitry Bolkhovskikh , ITriskTI , Max Is , Yuri Kozlov , Иван Павлов и Малянов Евгений Викторович . .PP Этот перевод является бесплатной документацией; прочитайте .UR https://www.gnu.org/licenses/gpl-3.0.html Стандартную общественную лицензию GNU версии 3 .UE или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ. .PP Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на .MT man-pages-ru-talks@lists.sourceforge.net .ME .