模拟实现memmove函数

1.描述

  1. void * memmove ( void * destination, const void * source, size_t num );
  2. 不限定具体指针类型,仅仅按字节拷贝,可能出现截断等问题。
  3. 优化memcpy了中的后目的重叠问题。
  4. 由于数组作为形参会退化,所以我们不能解决越界访问,以及空间不够的问题。
  5. 库函数没有安全检查,空指针,越界访问,以及空间不足会崩溃的问题。
  6. 返回值为指向目的首地址的指针。
  7. 源空间数据还是会被改变。

2.代码展示

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
void* mymemmove(void* dst, void* src, size_t num)
//void * memmove ( void * destination, const void * source, size_t num );
{
	assert(dst&&src);
	unsigned char* pdst = (unsigned char*)dst;
	unsigned char* psrc = (unsigned char*)src;
	//目的在源端之后,要从后向前拷贝
	if (psrc < pdst&&pdst < psrc + num)
	{
		for (size_t i = num - 1; i >= 0; --i)
		{
			pdst[i] = psrc[i];
		}
		return pdst;
	}
	else
	{
		for (size_t i = 0; i < num; ++i)
		{
			pdst[i] = psrc[i];
		}
		return pdst;
	}
}
void test7()
{
	/*char str1[] = "hello";
	char str2[] = "world";
	char str3[] = "hello";
	void* ret1 = memmove(str1, str1+2, 10);
	void* ret2 = mymemmove(str3, str3+2, 10);
	printf("%s %p %p\n", str1,str1,ret1);
	printf("%s %p %p\n", str3, str3, ret2);*/

	int arr1[5] = { 1,2,3,4,5 };
	int arr2[5] = { 6,7,8,9,10 };
	int arr3[5] = { 1,2,3,4,5 };

	void* ret3 = memmove(arr1, arr1 + 2,20 );
	//void* ret4 = mymemmove(arr3+1, arr3, 20);
	void* ret4 = mymemmove(arr3, arr3+2, 20);
	printf("%p %p\n", arr1, ret3);
	printf("%p %p\n", arr3, ret4);
	for (int i = 0; i < sizeof(arr3) / sizeof(arr3[0]); ++i)
	{
		printf("%d", arr3[i]);
	}
}
int main()
{
	test7();
	system("pause");
	return 0;
}

3.结果展示

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值