目录
memcpy函数的介绍
对于memcpy函数我们先来介绍一下他的用法:
memcpy函数可以把任意类型的数组元素进行拷贝,然后复制到另一个数组中。
注意,这里的 num 是字节数,比如一个整型的字节是 4,如果我们需要拷贝一个数组大小为10个元素的整型数组,那么这里的 num应为40。函数接收的第一个参数为需要被赋值的数组名,第二个参数为被拷贝的数组名。
其他类型同理:
以上就是memcpy函数的基本用法,下面我们来模拟实现memcpy函数的功能。
memcpy函数的模拟实现
首先我们观察memcpy函数的参数类型,分别是 void* ,void* ,size_t,所以当我们模拟实现时,参数的类型可以和他保持一致,这样能便于我们自己设计的函数也能实现相同的功能。考虑到memcpy函数可以拷贝任意类型的元素,所以我们可以根据数据在内存中的存储方式,一个字节一个字节的拷贝元素,从而达到拷贝所有元素的效果。
每一次拷贝一个字节后向后走一个字节继续进行拷贝 ,这就是模拟memcpy的原理。
因为我们传进去的参数是数组名,是首元素地址,但是是 void*类型,所以我们需要对其进行类型强制转换为 char* 进行拷贝。
这样我们自己的memcpy函数就模拟实现完成了。
memmove函数介绍
下面我们介绍memmove函数的用法:
由图可知,memmove函数的参数形式和memcpy函数是一样的,并且memmove函数的功能也是数组的拷贝,并且比memcpy函数功能更好。
比如,在数组长度范围内memmove函数可以实现数组自身的拷贝,并且可以选择拷贝的位置。
根据运行结果,我们不难看出memmove函数可以在数组arr1的起始位置开始拷贝从arr1第5个元素开始的元素,一共拷贝20个字节,即5个整型元素,覆盖掉原有的元素,保留剩余的元素。
这就是memmove函数的使用方法。
memmove函数的模拟实现
根据memmove函数的参数,和功能,我们不难想到模拟实现这个函数和memcpy相差不大。
但是要特别注意:
当我们传入的dest数组在scr数组前面时,我们的原理和memcpy函数一致就可以。
但是当我们传入的dest数组在scr数组后面时我们需要注意,经过不断的拷贝,我们需要的元素可能会被覆盖,导致我们想要的元素无法拷贝。
像这种情况,我们经过第一次的拷贝元素3被覆盖,导致第三次拷贝原本应该拷贝的 3 元素变成了1。所以遇到这种情况则需要我们从后向前拷贝,这样就能避免元素被覆盖的情况发生。
以上就是memmove函数的模拟实现!
本期内容就到这里啦,谢谢大家的观看!