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