C语言零基础第16讲:内存函数

目录

1.memcpy的使用和模拟实现

2.memmove的使用和模拟实现

3.memset的使用

4.memcmp的使用


正文开始

1.memcpy的使用和模拟实现

memcpy函数的原型如下:

复制代码
void* memcpy (void* destination, const void* source, size_t num);
  1. 从source的位置开始向后复制num个字节的数据,拷贝到destination指向的内存空间。
  2. 这个函数在遇到'\0'的时候并不会停下来。
  3. 如果source和destination有重叠的内存空间,在有的编译器上可以完成重叠的拷贝,达到预期效果,在有的编译器上不能完成
  4. memcpy函数会返回目标空间destination的起始地址。
  5. 对应的头文件:string.h。

我们来看一个示例:

我们来看一下memcpy函数的模拟实现:

但是,我们会发现,其实上述代码是有局限性的:

如上,我们发现,没有达到预期的效果。

如上,我们发现memcpy函数是可以达到预期效果的。

其实,memcpy这个库函数,处理的是不重叠的两块内存数据的拷贝,在有的编译器上可以完成重叠的拷贝,在有的编译器上不能完成。

如果想要完成重叠内存的拷贝,可以使用memmove函数。

2.memmove的使用和模拟实现

memmove函数的原型如下:

复制代码
void* memmove (void* destination, const void* source, size_t num);
  1. 和memcpy的区别在于,memmove函数处理的源内存空间和目标内存空间是可以重叠的。
  2. memmove既可以处理重叠的,又可以处理不重叠的。
  3. 对应的头文件:string.h。

我们来看一个示例:

那么,如何模拟实现这个函数呢?

观察一下,如果dest < source,无论是否重叠,我们都可以采用从前往后的拷贝方式。

以memmove(arr, arr+2, 20)为例,我们想实现3、4、5、6、7、6、7、8、9、10的效果,可以从前往后拷贝:

再观察一下,如果dest > source,重叠时可以采用从后往前拷贝的方式,不重叠时,既可以从前往后,又可以从后往前。

以memmove(arr+2, arr, 20)为例,我们想实现1、2、1、2、3、4、5、8、9、10的效果,可以从后往前拷贝:

于是乎,我们可以这样写代码:

我们来测试一下:

3.memset的使用

memset函数的原型如下:

复制代码
void* memset (void* ptr, int value, size_t num);

我们来看一个示例:

  1. memset函数是用来设置内存的,以字节为单位,将内存中的值设置成想要的内容。
  2. ptr指向被设置的内存块。
  3. value为要设置的值。
  4. num表示有多少个字节要被设置为这个值。
  5. 对应的头文件:string.h。

我们再看一个情况:

4.memcmp的使用

memcmp函数的原型如下:

复制代码
int memcmp (const void* ptr1, const void* ptr2, size_t num);
  1. 从ptr1和ptr2指向的位置开始,比较向后的num个字节。
  2. 如果是数字类数据,比较的是内存里的二进制值。
  3. 如果是非数字类数据,如字符,比较的是ASCII码值。
  4. 返回值有3种情况:<0、0、>0。
  5. 对应的头文件:string.h。

我们来看一个示例:

我们再来看一个示例:


完结

相关推荐
摇滚侠17 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
喜欢吃燃面17 小时前
数据结构算法题:list
开发语言·c++·学习·算法·1024程序员节
。TAT。18 小时前
C++ - 多态
开发语言·c++·学习·1024程序员节
武当豆豆18 小时前
C++编程学习(第42天)
开发语言·c++·学习
奔跑吧邓邓子18 小时前
【C语言实战(44)】C语言打造全能简易计算器:突破运算极限
c语言·实战·全能简易计算器
凉虾皮19 小时前
2024包河初中组
学习·算法·1024程序员节
kkkkk02110619 小时前
黑马微服务保险(一)
笔记·微服务·架构
hour_go20 小时前
【知识图谱】图神经网络(GNN)核心概念详解:从消息传递到实战应用
笔记·深度学习·神经网络·1024程序员节
摇滚侠20 小时前
全面掌握PostgreSQL关系型数据库,设置远程连接,笔记05,笔记06
java·数据库·笔记·postgresql
mpHH20 小时前
postgresql plancache --doing
数据库·学习·postgresql·1024程序员节