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

39 篇文章 0 订阅
27 篇文章 0 订阅

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


一、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这个函数,才能完成这个工作

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值