strcmp,strncmp函数详解

2024-04-29 23:12
文章标签 函数 详解 strcmp strncmp

本文主要是介绍strcmp,strncmp函数详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

字典序

字典序,也称为词典序或字序,是指对于两个字符串而言,逐个比较对应位置的字符,字符大小是按照ASCII码从小到大来比较的,如果字符串相同部分的前缀都相同,则较短的词有较小的字典序;如果比较的字符串长度不同,那么较短的字符串在前。

举例来说,在字典序中,字符串 "apple" 会排在 "banana" 之前,因为第一个不同的字符是 'a' 和 'b',而 'a' 在ASCII码中比 'b' 小。同样地,"apple" 会排在 "app" 之后,因为虽然 "app" 是 "apple" 的前缀,但 "apple" 长度更长。

字典序在多种场合中都有应用,特别是在编程和数据结构中,比如排序算法、字典树(Trie)等。在这些应用中,字典序提供了一种明确的顺序,使得我们可以对字符串进行排序、查找或其他操作。

 strcmp函数

strcmp函数是C语言中的一个字符串比较函数,用于比较两个字符串是否相等

注意这是根据两个字符串相同位置的字符对应的ASCII码值进行大小的比较,并不是比较字符串长度,也就是说这个结果取决于两个字符串中第一个不同字符的ASCII码的大小

函数原型为:

int strcmp(const char *s1, const char *s2);

函数参数:

  • s1:要比较的第一个字符串
  • s2:要比较的第二个字符串

函数返回值:

  • 如果s1和s2相同,则返回0
  • 如果s1小于s2,则返回一个负数
  • 如果s1大于s2,则返回一个正数

函数功能:

  • 比较两个字符串,并返回比较结果

函数实例:

#include <stdio.h>
#include <string.h>int main() {char str1[10] = "Hello";char str2[10] = "HellO";int result;result = strcmp(str1, str2);if(result == 0) {printf("两个字符串相等\n");} else {printf("两个字符串不相等\n");}return 0;
}

输出结果:

 两个字符串不相等

注意点

1,字符串的比较是按照字典序进行的,因此大小写字母的比较结果不同。

#include <stdio.h>
#include <string.h>int main()
{char str1[] = "hello";char str2[] = "HELLO";int ret = strcmp(str1, str2);if (ret == 0)printf("str1和str2相等\n");else if (ret > 0)printf("str1大于str2\n");elseprintf("str1小于str2\n");return 0;
}


 运行结果: 

str1大于str2

2,在比较字符串时,需要确保字符串以'\0'结尾,否则可能会导致比较结果不正确。

#include <stdio.h>
#include <string.h>int main()
{char str1[] = "hello";char str2[] = "hello";str1[5] = '!';int ret = strcmp(str1, str2);if (ret == 0)printf("str1和str2相等\n");else if (ret > 0)printf("str1大于str2\n");elseprintf("str1小于str2\n");return 0;
}

 运行结果: 

str1大于str2

分析: 

在这段代码中,我们将str1字符串的结尾标识符'\0'改成了'!',运行代码后,输出结果为"str1大于str2"。这是因为str1字符串没有以'\0'结尾,所以strcmp函数会继续比较下去,直到遇到str2字符串的结尾标识符'\0'。由于str1字符串比str2字符串长,所以str1被认为是大于str2。

模拟实现

strcmp函数是C语言标准库中的一个函数,用于比较两个字符串。它的基本功能是逐个比较两个字符串中的字符,直到找到一个不同的字符或者遇到字符串的结束符\0。基于这个定义,strcmp函数的模拟实现可以有多种方式。以下是一些可能的模拟实现方式:

1. 基本循环比较

这是最直接的模拟实现方式,使用循环逐个比较两个字符串中的字符。

 #include <stddef.h> // 包含 size_t 的定义  int my_strcmp_basic(const char *s1, const char *s2) { assert(s1&&s2); while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return *(const unsigned char *)s1 - *(const unsigned char *)s2;  } 

2. 指针算术实现

使用指针算术可以稍微简化代码,使循环内部的索引操作更加清晰。

int my_strcmp_pointer(const char *s1, const char *s2) {assert(s1&&s2);   while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return *(const unsigned char *)s1 - *(const unsigned char *)s2;  
}

3. 使用宏定义简化比较操作

可以定义一些宏来简化比较操作,但这通常不会改变算法的基本结构。

 #define COMPARE_CHARS(c1, c2) ((c1) - (c2))  int my_strcmp_macro(const char *s1, const char *s2) { 
assert(s1&&s2);  while (*s1 && (*s1 == *s2)) {  s1++;  s2++;  }  return COMPARE_CHARS(*s1, *s2);  } 

注意事项:

  1. 在所有实现中,我们都将字符转换为unsigned char类型,以避免在有符号字符为负时发生符号扩展问题。这是为了确保比较操作按预期进行。
  2. strcmp函数在比较字符串时区分大小写,这意味着大写和小写字母被视为不同的字符。如果你需要不区分大小写的比较,你需要实现一个不同的函数,比如strcasecmp或stricmp,并在比较之前将字符转换为相同的大小写。
  3. 在实际应用中,还需要考虑错误处理,比如当s1或s2为NULL时应该怎么做。标准库函数strcmp在任一参数为NULL时会返回未定义的结果,因此模拟实现时也应遵循相同的约定或提供额外的错误检查。
     

 strncmp函数

  1. strncmp函数是标准C库(C Standard Library)中的一个用于比较字符串的函数。
  2. 与strcmp函数类似,strncmp函数也用于比较两个C风格字符串(以空字符’\0’结尾的字符数组),但它只比较前n个字符。
  3. strncmp函数的原型定义在<string.h>头文件中。

它的原型如下:

int strncmp(const char *str1, const char *str2, size_t n);

其中,str1和str2分别是待比较的两个字符串的指针,n是指定要比较的字符数。

如果str1和str2的前n个字符相等(或者在比较过程中遇到了空字符’\0’),则strncmp返回0。
如果str1在字典顺序上小于str2(即str1的第一个不同字符的ASCII值小于str2的对应字符),则strncmp返回一个负整数。

如果str1在字典顺序上大于str2(即str1的第一个不同字符的ASCII值大于str2的对应字符),则strncmp返回一个正整数。

需要注意的是,比较的结果是根据字符的ASCII码值来确定的。如果n大于两个字符串中较短的字符串的长度,函数会一直比较到较短的字符串的末尾。

示例代码如下:

#include <stdio.h>
#include <string.h>int main() {char str1[] = "Hello";char str2[] = "World";int result = strncmp(str1, str2, 3);if (result < 0) {printf("str1 is less than str2\n");} else if (result > 0) {printf("str1 is greater than str2\n");} else {printf("str1 is equal to str2\n");}return 0;
}

这段代码比较了str1和str2的前3个字符,结果为"str1 is less than str2",因为'H'的ASCII码值为72,'W'的ASCII码值为87

strncmp和strcmp的区别

srcmp 和 strncmp 都是 C 语言的字符串比较函数,用于比较两个字符串的大小。它们的区别在于参数和返回值的处理方式。

  1. strcmp 函数:

    • 参数:strcmp 函数接受两个参数,分别是要比较的两个字符串。
    • 返回值:strcmp 函数的返回值为整型,比较结果为负数、零、正数三种情况,分别表示第一个字符串小于、等于、大于第二个字符串。
  2. strncmp 函数:

    • 参数:strncmp 函数除了接受两个字符串参数外,还额外接受一个整型参数 n,用于指定要比较的字符个数。
    • 返回值:strncmp 函数的返回值也为整型,比较结果与 strcmp 函数类似,表示第一个字符串小于、等于、大于第二个字符串。

不同之处:

  • strcmp 函数会比较两个字符串的每个字符,直到遇到不相等的字符或者一个字符串的结束符 '\0'。而 strncmp 函数会在指定的字符个数内进行比较,如果没有达到指定字符个数,就会根据比较结果返回。
  • strncmp 函数可以用于比较部分字符串,而 strcmp 函数只能比较整个字符串。

需要注意的是,在使用 strcmp 或 strncmp 函数比较字符串时,需要保证字符串以 '\0' 结尾,否则可能导致比较结果不正确。

这篇关于strcmp,strncmp函数详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/947410

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚