C语言模拟实现memcpy函数和memove函数

这两个函数是整形数组里的库函数

文章目录

  • 这两个函数是整形数组里的库函数
  • 一、memcpy--类型不限
    • 函数简介
    • 函数实现
  • 二、memove函数
    • 函数简介
  • 总结


一、memcpy–类型不限

函数简介

数memcy从source的位置开始向后复制num个字 节的数据到destination的内存位置。
●这个函数在遇到’\0’的时候并不会停下来。
●如果source和destination有 任何的重叠, 复制的结果都是未定义的。

memcpy(arr1, arr2);//函数名(目的地,源头,num)num要拷贝多少字节

函数实现

void* my_memcpy(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	
	while (num--){
	*(char*)dest = *(char*)src;//强制类型转换成位char类型一字节每次拷贝一个字节
	++(char*)dest;
	++(char*)src;
}
return ret;
}

二、memove函数

函数简介

void *memmove(void *str1, const void *str2, size_t n) 从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。

原理相同的话,但拷贝的方法不同,一个是从前往后拷贝
而memove是还会根据数据的不同进行相应的判断,判断号拷贝的区域使用从前向后拷贝是否会出现
原有数据被覆盖或者丢失的情况

void* my_memove(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	if (dest < src)
	{    //从前向后面拷贝

		while (num--) {
			*(char*)dest = *(char*)src;//强制类型转换成位char类型一字节每次拷贝一个字节
			++(char*)dest;
			++(char*)src;
		}
	}
	else//后-》前
	{//以防数据重叠导致数据的丢失
		*((char*)dest + num) = *((char*)src+ num); 
			
				

	}
return ret;
}

总结

库函数memcpy其实可以胜任自己拷贝自己的情况的,但是有些编译器不行,因为以C99的标准memcpy只需要完成拷贝工作即可但自己拷贝自己的时候,你得使用memove这个函数,才能完成这个工作

你可能感兴趣的:(算法,c++,c语言,c++,指针)