strcmp

来自cppreference.com
< c‎ | string‎ | byte
在标头 <string.h> 定义
int strcmp( const char* lhs, const char* rhs );

以字典序比较两个空终止字节字符串。

结果的符号是被比较的字符串中首对不同字符(都转译成 unsigned char)的值间的差的符号。

lhsrhs 不是指向空终止字节字符串的指针,则行为未定义。

参数

lhs, rhs - 指向要比较的空终止字节字符串的指针

返回值

若字典序中 lhs 先于 rhs 出现则为负值。

lhsrhs 比较相等则为零。

若字典序中 lhs 后于 rhs 出现则为正值。

注解

不同于 strcollstrxfrm,此函数不考虑本地环境。

示例

#include <stdio.h>
#include <string.h>
 
void demo(const char* lhs, const char* rhs)
{
    const int rc = strcmp(lhs, rhs);
    const char* rel = rc < 0 ? "先于" : rc > 0 ? "后于" : "等于";
    printf("[%s] %s [%s]\n", lhs, rel, rhs);
}
 
int main(void)
{
    const char* string = "Hello World!";
    demo(string, "Hello!");
    demo(string, "Hello");
    demo(string, "Hello there");
    demo("Hello, everybody!" + 12, "Hello, somebody!" + 11);
}

输出:

[Hello World!] 先于 [Hello!]
[Hello World!] 后于 [Hello]
[Hello World!] 先于 [Hello there]
[body!] 等于 [body!]

引用

  • C23 标准(ISO/IEC 9899:2024):
  • 7.24.4.2 The strcmp function (第 TBD 页)
  • C17 标准(ISO/IEC 9899:2018):
  • 7.24.4.2 The strcmp function (第 TBD 页)
  • C11 标准(ISO/IEC 9899:2011):
  • 7.24.4.2 The strcmp function (第 365-366 页)
  • C99 标准(ISO/IEC 9899:1999):
  • 7.21.4.2 The strcmp function (第 328-329 页)
  • C89/C90 标准(ISO/IEC 9899:1990):
  • 4.11.4.2 The strcmp function

参阅

比较两个字符串的一定数量字符
(函数)
(C95)
比较两个宽字符串
(函数)
比较两块缓冲区
(函数)
比较两个字符串,根据当前本地环境
(函数)