memchr
, wmemchr
Выполняет поиск символов в буфере.
Синтаксис
void *memchr(
const void *buffer,
int c,
size_t count
); // C only
void *memchr(
void *buffer,
int c,
size_t count
); // C++ only
const void *memchr(
const void *buffer,
int c,
size_t count
); // C++ only
wchar_t *wmemchr(
const wchar_t * buffer,
wchar_t c,
size_t count
); // C only
wchar_t *wmemchr(
wchar_t * buffer,
wchar_t c,
size_t count
); // C++ only
const wchar_t *wmemchr(
const wchar_t * buffer,
wchar_t c,
size_t count
); // C++ only
Параметры
buffer
Указатель на буфер.
c
Символ для поиска.
count
Число проверяемых символов.
Возвращаемое значение
В случае успешного выполнения возвращает указатель на первое расположение символа c
в buffer
. В противном случае возвращает значение NULL.
Замечания
memchr
и wmemchr
найдите первое вхождение c
в первых count
символах buffer
. Он останавливается при обнаружении c
или при проверке первых count
символов.
В языке C эти функции принимают указатель const
в качестве первого аргумента. В языке C++ доступны две перегрузки. Перегрузка, принимающая указатель на const
, возвращает указатель на const
; версия, которая принимает указатель на не-const
, возвращает указатель на не-const
. Макрос _CRT_CONST_CORRECT_OVERLOADS
определяется, если доступны обе const
версии этих функций и неconst
являются. Если требуется не-поведениеconst
для обеих перегрузк C++ в C++, определите символ _CONST_RETURN
.
Требования
Маршрут | Обязательный заголовок |
---|---|
memchr |
<memory.h> или <string.h> |
wmemchr |
<wchar.h> |
Дополнительные сведения о совместимости см. в разделе Совместимость.
Библиотеки
Все версии библиотек времени выполнения языка C.
Пример
// crt_memchr.c
#include <memory.h>
#include <stdio.h>
int ch = 'r';
char str[] = "lazy";
char string[] = "The quick brown dog jumps over the lazy fox";
char fmt1[] = " 1 2 3 4 5";
char fmt2[] = "12345678901234567890123456789012345678901234567890";
int main( void )
{
char *pdest;
int result;
printf( "String to be searched:\n %s\n", string );
printf( " %s\n %s\n\n", fmt1, fmt2 );
printf( "Search char: %c\n", ch );
pdest = memchr( string, ch, sizeof( string ) );
result = (int)(pdest - string + 1);
if ( pdest != NULL )
printf( "Result: %c found at position %d\n", ch, result );
else
printf( "Result: %c not found\n" );
}
Выходные данные
String to be searched:
The quick brown dog jumps over the lazy fox
1 2 3 4 5
12345678901234567890123456789012345678901234567890
Search char: r
Result: r found at position 12
См. также
Манипуляция буфером
_memccpy
memcmp
, wmemcmp
memcpy
, wmemcpy
memset
, wmemset
strchr
, , wcschr
_mbschr
_mbschr_l