[字符串和内存函数]strcmp和strncmp以及memcmp的区别

简介: [字符串和内存函数]strcmp和strncmp以及memcmp的区别

CPlus中对strcmp的介绍

#include <stdio.h>
#include <string.h>
int main ()
{
  char key[] = "apple";
  char buffer[80];
  do {
     printf ("Guess my favorite fruit? ");
     fflush (stdout);
     scanf ("%79s",buffer);
  } while (strcmp (key,buffer) != 0);
  puts ("Correct answer!");
  return 0;
}

CPlus中对strncmp的介绍

/* strncmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
  char str[][5] = { "R2D2" , "C3PO" , "R2A6" };
  int n;
  puts ("Looking for R2 astromech droids...");
  for (n=0 ; n<3 ; n++)
    if (strncmp (str[n],"R2xx",2) == 0)
    {
      printf ("found %s\n",str[n]);
    }
  return 0;
}

CPlus中对memcmp的介绍

/* memcmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
  char buffer1[] = "DWgaOtP12df0";
  char buffer2[] = "DWGAOTP12DF0";
  int n;
  n=memcmp ( buffer1, buffer2, sizeof(buffer1) );
  if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2);
  else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2);
  else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2);
  return 0;
}

区别

strcmp和strncmp的比较

strcmp和strncmp都是C语言中用于比较两个字符串的函数,它们的区别在于比较的方式长度限制

strcmp函数用于比较两个字符串,它会逐个比较两个字符串中对应位置上的字符,直到遇到不相等的字符或者到达字符串结束符’\0’。

如果两个字符串相等,返回值为0;

如果第一个字符串大于第二个字符串,返回值大于0;

如果第一个字符串小于第二个字符串,返回值小于0。

strncmp函数也用于比较两个字符串,但它额外需要一个参数来指定要比较的字符个数。它会比较两个字符串中前n个字符,其中n为第三个参数所指定的字符个数。

如果前n个字符都相等,则返回值为0;

否则,返回值遵循和strcmp相同的规则。

strcmp和memcmp的比较

memcmp和strcmp是C语言中用于比较字符串或者字节序列的函数,它们有一些区别。

memcmp函数用于比较两个内存区域的内容。这个函数通过比较两个内存区域的字节进行操作,并返回一个整数值来表示比较结果。

如果返回值小于0,表示第一个内存区域小于第二个;

如果返回值大于0,表示第一个内存区域大于第二个;

如果返回值等于0,表示两个内存区域相等。

memcmp函数比较的是字节序列,不仅可以用来比较字符串,也可以用来比较其他类型的数据。

strncmp是strcmp的一种变体函数,它除了比较两个字符串的内容外,还可以指定比较的长度。它接受三个参数,分别是要比较的两个字符串和要比较的长度。

strcmp函数用于比较两个字符串的内容。这个函数通过比较两个字符串中对应位置的字符进行操作,并返回一个整数值来表示比较结果。

如果返回值小于0,表示第一个字符串小于第二个;

如果返回值大于0,表示第一个字符串大于第二个;

如果返回值等于0,表示两个字符串相等。strcmp函数只能用来比较字符串。

所以,区别在于memcmp函数可以比较字节序列,而strcmp函数只能比较字符串。此外,对于包含空字符的字符串,strcmp函数在遇到空字符时会停止比较,而memcmp函数则会继续比较。

相关文章
|
5天前
|
C语言
C语言—内存函数的实现和模拟实现(内存函数的丝绸之路)
C语言—内存函数的实现和模拟实现(内存函数的丝绸之路)
18 0
|
1天前
|
C语言 C++
C语言进阶⑭(内存函数_以字节操作)momcpy+mommove+memcmp+memset
C语言进阶⑭(内存函数_以字节操作)momcpy+mommove+memcmp+memset
5 0
|
6天前
|
存储 编译器 C语言
C语言:字符函数 & 字符串函数 & 内存函数
C语言:字符函数 & 字符串函数 & 内存函数
16 2
|
6天前
|
存储
浮点数在内存中的存储
浮点数在内存中的存储
26 0
|
6天前
|
存储
数据在内存中的存储之整数存储
数据在内存中的存储之整数存储
21 0
|
3天前
|
存储 算法 关系型数据库
实时计算 Flink版产品使用合集之在Flink Stream API中,可以在任务启动时初始化一些静态的参数并将其存储在内存中吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
17 4
|
5天前
|
存储 小程序 编译器
数据在内存中的存储(探索内存的秘密)
数据在内存中的存储(探索内存的秘密)
11 0
|
6天前
|
存储 监控 NoSQL
Redis处理大量数据主要依赖于其内存存储结构、高效的数据结构和算法,以及一系列的优化策略
【5月更文挑战第15天】Redis处理大量数据依赖内存存储、高效数据结构和优化策略。选择合适的数据结构、利用批量操作减少网络开销、控制批量大小、使用Redis Cluster进行分布式存储、优化内存使用及监控调优是关键。通过这些方法,Redis能有效处理大量数据并保持高性能。
25 0
|
1天前
|
存储 弹性计算 监控
【阿里云弹性计算】深入阿里云ECS配置选择:CPU、内存与存储的最优搭配策略
【5月更文挑战第20天】阿里云ECS提供多种实例类型满足不同需求,如通用型、计算型、内存型等。选择CPU时,通用应用可选1-2核,计算密集型应用推荐4核以上。内存选择要考虑应用类型,内存密集型至少4GB起。存储方面,系统盘和数据盘容量依据应用和数据量决定,高性能应用可选SSD或高效云盘。结合业务特点和预算制定配置方案,并通过监控应用性能适时调整,确保资源最优利用。示例代码展示了使用阿里云CLI创建ECS实例的过程。
29 5
|
6天前
|
存储 编译器 程序员
C语言:数据在内存中的存储
C语言:数据在内存中的存储
15 2