命名空间
变体
操作

strrchr

来自 cppreference.cn
< c‎ | string‎ | byte
定义于头文件 <string.h>
char* strrchr( const char* str, int ch );
(1)
/*QChar*/* strrchr( /*QChar*/* str, int ch );
(2) (自 C23 起)
1) 在 `str` 指向的以空字符结尾的字节字符串中查找 `ch`(在转换为 `char` 后,如同通过 `(char)ch` 转换)。终止空字符被认为是字符串的一部分,如果查找 `'\0'` 则可以找到。每个字符都解释为 `unsigned char`。
2) 类型通用函数,等同于 (1)。令 T 为不合格字符对象类型。
  • 如果 `str` 的类型为 `const T*`,则返回类型为 `const char*`。
  • 否则,如果 `str` 的类型为 `T*`,则返回类型为 `char*`。
  • 否则,行为未定义。
如果抑制这些通用函数中的任何一个的宏定义以访问实际函数(例如,如果使用 `(strrchr)` 或函数指针),则实际函数声明 `(1)` 将可见。

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

目录

[编辑] 参数

str - 指向要分析的以空字符结尾的字节字符串的指针
ch - 要搜索的字符

[编辑] 返回值

指向 `str` 中找到的字符的指针,如果未找到此类字符则为 null 指针。

[编辑] 示例

#include <stdio.h>
#include <string.h>
 
int main(void)
{
    char szSomeFileName[] = "foo/bar/foobar.txt";
    char* pLastSlash = strrchr(szSomeFileName, '/');
    char* pszBaseName = pLastSlash ? pLastSlash + 1 : szSomeFileName;
    printf("Base Name: %s", pszBaseName);
}

输出

Base Name: foobar.txt

[编辑] 参考

  • C23 标准 (ISO/IEC 9899:2024)
  • 7.24.5.5 strrchr 函数 (p: TBD)
  • C17 标准 (ISO/IEC 9899:2018)
  • 7.24.5.5 strrchr 函数 (p: TBD)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.24.5.5 strrchr 函数 (p: 368-369)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.21.5.5 strrchr 函数 (p: 331)
  • C89/C90 标准 (ISO/IEC 9899:1990)
  • 4.11.5.5 strrchr 函数

[编辑] 参阅

查找字符的第一次出现
(函数) [编辑]
在一个字符串中查找另一个字符串中任意字符的第一个位置
(函数) [编辑]
C++ 文档 for strrchr