概述
文章目录
- 一、函数简介
- 1、memcpy
- 2、memmove
- 二、代码实现
- 1、memcpy
- 2、memmove
- 三、小结
一、函数简介
1、memcpy
void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置,这个函数在遇到 ‘ ’ 的时候并不会停下来,如果source和destination有任何的重叠,复制的结果都是未定义的。
2、memmove
void * memmove ( void * destination, const void * source, size_t num );
memmove和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的,如果源空间和目标空间出现重叠,就得使用memmove函数处理。
二、代码实现
1、memcpy
void* my_memcpy(void* dest,const void* src,size_t count)
{
assert(dest && src);
void* ret = dest;
while(count--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
return ret;
}
int main()
{
/*char arr1[30] = "Hello ";
char arr2[] = "Worldxxxxx";*/
int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[5] = { 0 };
int sz = sizeof(arr2) / sizeof(arr2[0]);
my_memcpy(arr2,arr1,20);
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr2[i]);
}
//printf("%sn",arr1);
return 0;
}
实现效果
2、memmove
void my_memmove(void* dest,const void* src,size_t count)
{
assert(dest && src);
void* ret = dest;
if (dest < src)
{
//从前往后拷贝
while (count--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
}
else
{
//从后往前拷贝
while (count--)
{
*((char*)dest + count) = *((char*)src + count);
}
}
return ret;
}
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
my_memmove(arr+2,arr,20);
int sz = sizeof(arr) / sizeof(arr[0]);
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
实现效果
三、小结
因为memcpy和memmove是对内存进行操作的,所以memcpy和memmove还可以实现其他数据类型的拷贝,例如字符、浮点型、结构体等等,函数的调用方法也是一样所以不过多演示。
最后
以上就是迷路小猫咪为你收集整理的模拟实现memcpy和memmove函数一、函数简介二、代码实现三、小结的全部内容,希望文章能够帮你解决模拟实现memcpy和memmove函数一、函数简介二、代码实现三、小结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复