Defined in header <string.h> | ||
---|---|---|
char* strpbrk( const char* dest, const char* breakset ); |
Scans the null-terminated byte string pointed to by dest
for any character from the null-terminated byte string pointed to by breakset
, and returns a pointer to that character.
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 %d 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.
http://en.cppreference.com/w/c/string/byte/strpbrk