memcmp内存比较函数

1.头文件:string.h

**2.函数原型:**int memcmp(const void *ptr1, const void *ptr2, size_t num)

**3.函数功能:**比较两块内存中数据的大小

4.参数解释:

比较 ptr1 和 ptr2 两个指针所指向的两块内存中的前 num 个字节

5.返回值:

逐字节比较

当ptr1指针指向的内存中的数据 小于 ptr2指针指向的内存中的数据 ,返回 -1

当ptr1指针指向的内存中的数据 等于 ptr2指针指向的内存中的数据 ,返回 0

当ptr1指针指向的内存中的数据 大于 ptr2指针指向的内存中的数据 ,返回 1

6.实例代码:

++memcmp函数逐字节比较时,只根据第一次不相同的字节来返回结果值++

例如在比较nums3和nums4中的数据时,虽然nums3中后三个数据全部比nums4中后三个数据大,但是nums3的第二个数据小于nums4的第二个数据,因此返回-1

cpp 复制代码
int nums1[] = { 1,2,3,4,5,6,7,8,9 };
int nums2[] = { 1,2,3,4,9 };
printf("%d\n", memcmp(nums1, nums2, sizeof(int) * 4));//0,比较前4个数据
printf("%d\n", memcmp(nums1, nums2, sizeof(int) * 5));//-1,比较前5个数据
cpp 复制代码
 int nums3[] = { 1,0,3,3,3 };
 int nums4[] = { 1,2,0,0,0 };
 printf("%d\n", memcmp(nums3, nums4, sizeof(int) * 5));//-1,比较前5个数据

可以不比较完整的一个数据,那么就要看数据的存储是大端存储还是小端存储

我的机器存储是小端存储,那么nums1中的数据存储:01 00 00 00 02 00 00 00 ++04++ 00 00 00

nums2中的数据存储:01 00 00 00 02 00 00 00 ++03++ 00 00 00

只比较前9个字节,就是比较到加粗字节处(04 和 03),因此返回结果为1

cpp 复制代码
int nums5[] = { 1,2,4 };
int nums6[] = { 1,2,3 };
printf("%d\n", memcmp(nums5, nums6, 9));//1,比较前9个字节

memcmp函数可以比较任意数据类型(比较结构体等数据不太好观察,此处不做代码演示)

cpp 复制代码
char arr1[] = "abcdeg";
char arr2[] = "abcdef";
printf("%d\n", memcmp(arr1, arr2, 6));//1,比较前6个字节
相关推荐
leaves falling1 小时前
c语言单链表
c语言·开发语言
请注意这个女生叫小美1 小时前
C语言实例22 乒乓球比赛
c语言
方便面不加香菜1 小时前
数据结构--链式结构二叉树
c语言·数据结构
Tingjct1 小时前
十大排序算法——交换排序(一)
c语言·开发语言·数据结构·算法·排序算法
senijusene1 小时前
数据结构与算法:栈的基本概念,顺序栈与链式栈的详细实现
c语言·开发语言·算法·链表
星火开发设计2 小时前
命名空间 namespace:解决命名冲突的利器
c语言·开发语言·c++·学习·算法·知识
啟明起鸣2 小时前
【Nginx 网关开发】上手 Nginx,简简单单启动一个静态 html 页面
运维·c语言·前端·nginx·html
卡里笔记2 小时前
C语言版2048小游戏
c语言
梵刹古音2 小时前
【C语言】 循环结构
c语言·开发语言·算法
皮皮哎哟2 小时前
冒泡排序与数组传递全解析 一维二维指针数组及二级指针应用指南
c语言·算法·冒泡排序·二维数组·指针数组·传参·二级指针