C++ 参考手册
- C++11
- C++14
- C++17
- C++20
- C++ 编译器支持情况表
- 独立与宿主实现
- C++ 语言
- C++ 关键词
- 预处理器
- C++ 标准库头文件
- 具名要求
- 功能特性测试 (C++20)
- 工具库
- 类型支持(基本类型、RTTI、类型特性)
- 概念库 (C++20)
- 错误处理
- 动态内存管理
- 日期和时间工具
- 字符串库
- std::basic_string
- std::basic_string_view
- 空终止字节字符串
- 空终止多字节字符串
- 空终止宽字符串
- std::towlower
- std::wctype
- std::iswctype
- std::iswcntrl
- std::iswprint
- std::iswspace
- std::iswblank
- std::iswgraph
- std::iswpunct
- std::iswalnum
- std::iswalpha
- std::iswupper
- std::iswlower
- std::iswdigit
- std::iswxdigit
- std::towupper
- std::wctrans
- std::towctrans
- std::wcstol, std::wcstoll
- std::wcstoul, std::wcstoull
- std::wcstof, std::wcstod, std::wcstold
- std::wcstoimax, std::wcstoumax
- std::wcslen
- std::wcscpy
- std::wcsncpy
- std::wcscat
- std::wcsncat
- std::wcscmp
- std::wcscoll
- std::wcsncmp
- std::wcsxfrm
- std::wcschr
- std::wcsrchr
- std::wcspbrk
- std::wcsspn
- std::wcscspn
- std::wcsstr
- std::wcstok
- std::wmemcpy
- std::wmemmove
- std::wmemcmp
- std::wmemchr
- std::wmemset
- std::char_traits
- 注释
- 容器库
- 迭代器库
- 范围库 (C++20)
- 算法库
- 数值库
- 输入/输出库
- 文件系统库
- 本地化库
- 正则表达式库
- 原子操作库
- 线程支持库
- 实验性 C++ 特性
- 有用的资源
- 索引
- std 符号索引
- 协程支持 (C++20)
- C++ 关键词
std::wcstok
定义于头文件 <cwchar>
|
||
wchar_t* wcstok( wchar_t* str, const wchar_t* delim, wchar_t ** ptr); |
||
寻找 str
所指向的空终止宽字符串中的下个记号。以 delim
所指向的空终止宽字符串鉴别分隔符。
此函数被设计为调用多次以从同一字符串获得相继的记号。
- 若 str != NULL ,则调用被当做
std::wcstok
首次对此具体宽字符的调用。函数搜索首个不含于delim
的字符。
- 若找不到这种宽字符,则
str
中完全无记号,而函数返回空指针。 - 若找到这种宽字符,则它是记号起始。然后函数从该点搜索首个含于
delim
的宽字符。
- 若找不到这种宽字符,则
str
只有一个记号,而对std::wcstok
的将来调用将返回空指针 - 若找到这种宽字符,则以空宽字符 L'\0' 替换它,并存储分析状态(典型地为指向后一宽字符的指针)于用户提供位置 *ptr 。
- 若找不到这种宽字符,则
- 然后函数返回指向记号起始的指针
- 若找不到这种宽字符,则
- 若 str == NULL ,则调用被当作对
std::wcstok
的后继调用:函数从带同一 *ptr 的先前调用所留下的位置开始持续。行为与如同将指向后随上次检测的记号的宽字符的指针作为 str 传递相同。
- 若 str != NULL ,则调用被当做
参数
str | - | 指向要记号化的空终止宽字符串的指针 |
delim | - | 指向标识分隔符的空终止宽字符串的指针 |
ptr | - | 指向 wchar_t* 类型对象的指针, wcstok 以之存储分析器的内部状态
|
返回值
返回指向下个记号起始的指针,或若无更多记号则为空指针。
注意
此函数是破坏性的:它写入 L'\0' 字符于字符串 str
的元素。特别是,宽字符串字面量不能用作 std::wcstok
的首参数。
不同于 std::strtok ,此函数不更新静态存储:它存储分析状态于用户提供的位置。
不同于大多数其他记号化器, std::wcstok
中的分隔符能对于后继记号不同,而且甚至能依赖于先前记号的内容。
示例
运行此代码
#include <cwchar> #include <iostream> int main() { wchar_t input[100] = L"A bird came down the walk"; wchar_t* buffer; wchar_t* token = std::wcstok(input, L" ", &buffer); while (token) { std::wcout << token << '\n'; token = std::wcstok(nullptr, L" ", &buffer); } }
输出:
A bird came down the walk
参阅
寻找字节字符串中的下个记号 (函数) |