< c‎ | string‎ | byte
Defined in header <string.h>
void* memchr( const void* ptr, int ch, size_t count );

Finds the first occurrence of ch (after conversion to unsigned char as if by (unsigned char)ch) in the initial count characters (each interpreted as unsigned char) of the object pointed to by ptr.

The behavior is undefined if access occurs beyond the end of the array searched. The behavior is undefined if ptr is a null pointer.


[edit] Parameters

ptr - pointer to the object to be examined
ch - character to search for
count - number of characters to examine

[edit] Return value

Pointer to the location of the character, or NULL if no such character is found.

[edit] Example

#include <stdio.h>
#include <string.h>
int main(void)
    char str[] = "ABCDEFG";
    char *ps = memchr(str,'D',strlen(str));
    if (ps != NULL)
       printf ("search character found:  %s\n", ps);
       printf ("search character not found\n");
    return 0;


search character found:  DEFG

[edit] References

  • C11 standard (ISO/IEC 9899:2011):
  • The memchr function (p: 367)
  • C99 standard (ISO/IEC 9899:1999):
  • The memchr function (p: 330)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • The memchr function

[edit] See also

finds the first occurrence of a character
C++ documentation for memchr