Namespaces
Variants

wcscmp

From cppreference.net
< c ‎ | string ‎ | wide
定义于头文件 <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 wcscmp 函数 (页: TBD)
  • C17 标准 (ISO/IEC 9899:2018):
  • 7.29.4.4.1 wcscmp 函数 (页: TBD)
  • C11 标准 (ISO/IEC 9899:2011):
  • 7.29.4.4.1 wcscmp 函数 (页: 433)
  • C99标准 (ISO/IEC 9899:1999):
  • 7.24.4.4.1 wcscmp函数 (p: 379)

参见

(C95)
比较两个宽字符串的指定数量字符
(函数)
(C95)
比较两个数组的指定数量宽字符
(函数)
比较两个字符串
(函数)
(C95)
根据当前区域设置比较两个宽字符串
(函数)
C++ 文档 for wcscmp