命名空间
变体
操作

strpbrk

来自 cppreference.com
< c‎ | string‎ | byte
定义在头文件 <string.h>
char *strpbrk( const char *dest, const char *breakset );
(1)
/*QChar*/ *strpbrk( /*QChar*/ *dest, const char *breakset );
(2) (自 C23)
1 ) 扫描由 dest 指向的以 null 结尾的字节字符串,查找由 breakset 指向的以 null 结尾的字节字符串中的任何字符,并返回指向该字符的指针。
2)(1) 等效的类型通用函数。设 T 为非限定字符对象类型。
  • 如果 dest 的类型为 const T*,则返回类型为 const char*
  • 否则,如果 dest 的类型为 T*,则返回类型为 char*
  • 否则,行为未定义。
如果每个这些通用函数的宏定义被抑制以访问实际函数(例如,如果使用 (strpbrk) 或函数指针),则实际函数声明 (1) 将变得可见。

如果 destbreakset 不是指向以 null 结尾的字节字符串的指针,则行为未定义。

内容

[编辑] 参数

dest - 指向要分析的以 null 结尾的字节字符串的指针
breakset - 指向包含要搜索的字符的以 null 结尾的字节字符串的指针

[编辑] 返回值

指向 dest 中第一个也位于 breakset 中的字符的指针,如果不存在这样的字符,则为 null 指针。

[编辑] 注释

该名称代表“字符串指针中断”,因为它返回指向第一个分隔符(“中断”)字符的指针。

[编辑] 示例

#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);
}

输出

There are 5 words

[编辑] 参考文献

  • C23 标准 (ISO/IEC 9899:2024)
  • 7.24.5.4 strpbrk 函数 (p: TBD)
  • C17 标准 (ISO/IEC 9899:2018)
  • 7.24.5.4 strpbrk 函数 (p: TBD)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.24.5.4 strpbrk 函数 (p: 368)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.21.5.4 strpbrk 函数 (p: 331)
  • C89/C90 标准 (ISO/IEC 9899:1990)
  • 4.11.5.4 strpbrk 函数

[编辑] 另请参见

返回由不包含在另一个字节字符串中的字符组成的最大初始段的长度
仅包含在另一个字节字符串中未找到的字符
(函数) [编辑]
查找字符的第一次出现
(函数) [编辑]
在字节字符串中查找下一个标记
(函数) [编辑]
C++ 文档 for strpbrk