打开常用C语言常用内存函数的大门 ——memcmp函数及其模拟实现(完结篇)

1. 前言

本文是C语言常用内存函数的最后一个函数 —— memcmp函数。

希望各位观众佬爷们能够学会并灵活的使用这四个常用的内存函数:

内存函数函数原型作用
memcpyvoid* memcpy(void* destination, const void* source, size_t num)将源空间里的num个字节内容拷贝到目标空间
memmovevoid* memmove(void* destination, const void* source, size_t num)将源空间里的num个字节内容拷贝到目标空间(注意与memcpy函数的区别)
memsetvoid* memset(void* ptr, int value, size_t num)以value的值覆盖所指向目标空间往后的num个字节的内容(包括所指向开始位置)
memcmpint memcmp(const void* ptr1, const void* ptr2, size_t num)比较两个所指向的内存空间的num个字节的内容。如果提前发现不同的内容时,就终止比较,返回一个非0值。

2. memcmp函数

memcmp函数的作用:比较两个不同数据对象的num个字节的内容。如果提前发现不同的内容时,就终止比较,返回一个非0值。反之,返回0。

2.1 memcmp函数的原型

memcmp函数的原型

int memcmp(const void* ptr1, const void* ptr2, size_t num);

2.2 memcmp的返回值

memcmp的返回值
如果看不懂上述的表格,没有关系,我来给你解释:

取出ptr1和ptr2空间的前num个字节的内容,以字节为单位进行比较。如果ptr1所指向空间的单位字节的值大于ptr2所指向空间的值,那么就返回大于0的值。如果是小于的话,就返回小于0的值。如果是等于的话,就返回0。

 小于的情况
等于的情况
大于0的情况

2.2 memcmp的形参

形参类型作用
ptr1const void*指向第一个待比较空间的内容
ptr2const void*指向第二个待比较空间的内容
numsize_t指明从开始位置往后比较多少个字节的内容(注:开始的位置就已经算字节的内容了)

2.3 memcmp函数的使用

下面我给出一个案例,分别改变它们比较的字节数的多少,请你判断一下输出的结果(本代码是在VS2022环境下运行的):
memcmp函数练习
结果:
答案
怎么样,你做对了吗。

相信看到这里的读者,已经对这个函数的使用了然于胸了。

那么,又来到了我们熟悉的环节,模拟实现memcmp函数:

3. memcmp函数的模拟实现

这个函数的模拟实现并不难,读者们应该比较容易理解下面给出的代码:
模拟实现
模拟实现

4. 总结

本文讲解了memcmp函数的使用及其模拟实现。另外,本篇也是C语言常用的内存函数完结篇了,如果前面还有没看的函数,记得补一下哦!!!👍👍👍🎇

**学习很难,但坚持一定很酷!!!**🥇🥇🥇

  • 19
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值