wcscmp
来自 cppreference.cn
在头文件 <wchar.h> 中定义 |
||
int wcscmp( const wchar_t* lhs, const wchar_t* rhs ); |
(自 C95 起) | |
按字典序比较两个空终止宽字符串。
结果的符号是所比较字符串中第一对不同宽字符值的差的符号。
若 lhs 或 rhs 不是指向空终止宽字符串的指针,则行为未定义。
目录 |
[编辑] 参数
lhs, rhs | - | 指向要比较的以空字符结尾的宽字符串的指针 |
[编辑] 返回值
如果 lhs 在字典序上出现在 rhs 之前,则返回负值。
若 lhs 与 rhs 比较相等,则为零。
如果 lhs 在字典序上出现在 rhs 之后,则返回正值。
[编辑] 注意
此函数与 wcscoll 不同,它不对本地环境敏感,且当一起使用来自不同 Unicode 块的字符时,或当代码单元的顺序不匹配任何排序规则时,其顺序可能没有意义。
[编辑] 示例
运行此代码
#include <locale.h> #include <stdio.h> #include <wchar.h> void demo(const wchar_t* lhs, const wchar_t* rhs) { int rc = wcscmp(lhs, rhs); const char *rel = rc < 0 ? "precedes" : rc > 0 ? "follows" : "equals"; setlocale(LC_ALL, "en_US.utf8"); printf("[%ls] %s [%ls]\n", lhs, rel, rhs); } int main(void) { const wchar_t* string = L"どうもありがとうございます"; demo(string, L"どうも"); demo(string, L"助かった"); demo(string + 9, L"ありがとうございます" + 6); }
可能的输出
[どうもありがとうございます] follows [どうも] [どうもありがとうございます] precedes [助かった] [ざいます] equals [ざいます]
[编辑] 引用
- C23 标准 (ISO/IEC 9899:2024)
- 7.29.4.4.1 The wcscmp function (p: TBD)
- C17 标准 (ISO/IEC 9899:2018)
- 7.29.4.4.1 The wcscmp function (p: TBD)
- C11 标准 (ISO/IEC 9899:2011)
- 7.29.4.4.1 The wcscmp function (p: 433)
- C99 标准 (ISO/IEC 9899:1999)
- 7.24.4.4.1 The wcscmp function (p: 379)
[编辑] 参阅
(C95) |
比较两个宽字符串中的一定数量的字符 (函数) |
(C95) |
比较两个数组中一定数量的宽字符 (函数) |
比较两个字符串 (函数) | |
(C95) |
根据当前语言环境比较两个宽字符串 (函数) |
C++ documentation for wcscmp
|