命名空间
变体
操作

wcschr

来自 cppreference.com
< c‎ | string‎ | wide
在头文件 <wchar.h> 中定义
wchar_t *wcschr( const wchar_t *str, wchar_t ch );
(1) (自 C95 起)
/*QWchar_t*/ *wcschr( /*QWchar_t*/ *str, wchar_t ch );
(2) (自 C23 起)
1)str 指向的宽字符串中查找宽字符 ch 的第一个出现位置。
2)(1) 等效的类型泛型函数。设 T 为一个非限定的宽字符对象类型。
  • 如果 str 的类型为 const T*,则返回类型为 const wchar_t*
  • 否则,如果 str 的类型为 T*,则返回类型为 wchar_t*
  • 否则,行为未定义。
如果这些泛型函数中的每一个的宏定义都被抑制以访问实际的函数(例如,如果 (wcschr) 或函数指针被使用),则实际的函数声明 (1) 变为可见的。

内容

[编辑] 参数

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

[编辑] 返回值

指向 str 中找到的字符的指针,如果未找到这样的字符,则为一个空指针。

[编辑] 示例

#include <wchar.h>
#include <stdio.h>
#include <locale.h>
 
int main(void)
{
    wchar_t arr[] = L"白猫 黒猫 кошки";
    wchar_t *cat = wcschr(arr, L'猫');
    wchar_t *dog = wcschr(arr, L'犬');
 
    setlocale(LC_ALL, "en_US.utf8");
    if(cat)
        printf("The character 猫 found at position %td\n", cat-arr);
    else
        puts("The character 猫 not found");
 
    if(dog)
        printf("The character 犬 found at position %td\n", dog-arr);
    else
        puts("The character 犬 not found");
}

输出

The character 猫 found at position 1
The character 犬 not found

[编辑] 参考文献

  • C11 标准 (ISO/IEC 9899:2011)
  • 7.29.4.5.1 wcschr 函数 (p: 435)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.24.4.5.1 wcschr 函数 (p: 381)

[编辑] 参见

在宽字符串中查找宽字符的最后一个出现位置
(函数) [编辑]
在一个宽字符串中查找另一个宽字符串中任何宽字符的第一个位置
(函数) [编辑]
C++ 文档 for wcschr