STRSTR(3) Library Functions Manual STRSTR(3)

strstr, strcasestr, strnstrlocate a substring in a string

Standard C Library (libc, -lc)

#include <string.h>

char *
strstr(const char *haystack, const char *needle);

char *
strcasestr(const char *haystack, const char *needle);

char *
strnstr(const char *haystack, const char *needle, size_t len);

#include <string.h>
#include <xlocale.h>

char *
strcasestr_l(const char *haystack, const char *needle, locale_t loc);

The () function locates the first occurrence of the null-terminated string needle in the null-terminated string haystack.

The () function is similar to strstr(), but ignores the case of both strings.

The () function locates the first occurrence of the null-terminated string needle in the string haystack, where not more than len characters are searched. Characters that appear after a ‘\0’ character are not searched. Since the strnstr() function is a FreeBSD specific API, it should only be used when portability is not a concern.

While the () function uses the current locale, the () function may be passed a locale directly. See xlocale(3) for more information.

If needle is an empty string, haystack is returned; if needle occurs nowhere in haystack, NULL is returned; otherwise a pointer to the first character of the first occurrence of needle is returned.

The following sets the pointer ptr to the "Bar Baz" portion of largestring:

const char *largestring = "Foo Bar Baz";
const char *smallstring = "Bar";
char *ptr;

ptr = strstr(largestring, smallstring);

The following sets the pointer ptr to NULL, because only the first 4 characters of largestring are searched:

const char *largestring = "Foo Bar Baz";
const char *smallstring = "Bar";
char *ptr;

ptr = strnstr(largestring, smallstring, 4);

memchr(3), memmem(3), strchr(3), strcspn(3), strpbrk(3), strrchr(3), strsep(3), strspn(3), strtok(3), wcsstr(3), xlocale(3)

The strstr() function conforms to ISO/IEC 9899:1990 (“ISO C90”).

October 11, 2001 macOS 15.0