| Defined in header <string.h> | ||
|---|---|---|
| char *strpbrk( const char *dest, const char *breakset ); | (1) | |
| /*QChar*/ *strpbrk( /*QChar*/ *dest, const char *breakset ); | (2) | (since C23) | 
dest for any character from the null-terminated byte string pointed to by breakset, and returns a pointer to that character.T be an unqualified character object type. dest is of type const T*, the return type is const char*. dest is of type T*, the return type is char*. (strpbrk) or a function pointer is used), the actual function declaration (1) becomes visible.The behavior is undefined if either dest or breakset is not a pointer to a null-terminated byte string.
| dest | - | pointer to the null-terminated byte string to be analyzed | 
| breakset | - | pointer to the null-terminated byte string that contains the characters to search for | 
Pointer to the first character in dest, that is also in breakset, or null pointer if no such character exists.
The name stands for "string pointer break", because it returns a pointer to the first of the separator ("break") characters.
#include <stdio.h>
#include <string.h>
 
int main(void)
{
    const char* str = "hello world, friend of mine!";
    const char* sep = " ,!";
 
    unsigned int cnt = 0;
    do {
       str = strpbrk(str, sep); // find separator
       if(str) str += strspn(str, sep); // skip separator
       ++cnt; // increment word count
    } while(str && *str);
 
    printf("There are %u words\n", cnt);
}Output:
There are 5 words
| returns the length of the maximum initial segment that consists of only the characters not found in another byte string (function) | |
| finds the first occurrence of a character (function) | |
| (C11) | finds the next token in a byte string (function) | 
| C++ documentation for strpbrk | |
    © cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
    https://en.cppreference.com/w/c/string/byte/strpbrk