我是靠谱客的博主 迷路小猫咪,最近开发中收集的这篇文章主要介绍模拟实现memcpy和memmove函数一、函数简介二、代码实现三、小结,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

文章目录

  • 一、函数简介
    • 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函数一、函数简介二、代码实现三、小结所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部