实现memcpy和memmove函数

本文介绍了C语言中的memcpy和memmove函数,用于内存拷贝。虽然两者功能相似,但当源和目标区域有重叠时,memmove确保拷贝的正确性,而memcpy可能出错。通过代码示例展示了memcpy和memmove的使用,同时提到了memccpy函数,它会在遇到特定值时停止复制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

memcpy()函数和memmove()函数都是C语言中的库函数,在头文件string.h中,作用是拷贝一定长度的内存的内容,原型分别如下:

void *memcpy(void *dst, const void *src, size_t count);

void *memmove(void *dst, const void *src, size_t count); 

    它们的作用是一样的,唯一的区别是:当内存发生局部重叠的时候,memmove保证拷贝的结果是正确的;memcpy不保证拷贝的结果的正确。

第一种情况:拷贝重叠的区域不会出现问题,内容均可以正确的被拷贝。
第二种情况:问题出现在右边的两个字节,这两个字节的原来的内容首先就被覆盖了,而且没有保存。所以接下来拷贝的时候,拷贝的是已经被覆盖的内容,显然这是有问题的。
实际上,memcpy只是memmove的一个子集。

代码实现memcpy函数如下:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<assert.h>

void *my_memcpy(void *dest, void *src, size_t count)//内存拷贝
{
	assert(dest);
	assert(src);
	char *p1 = (char *)dest;
	char *p2 = (char *)src;
	while (count--)
	{
		*p1++ = *p2++;
	}
	return dest;
}

int main()
{
	float arr[10] = { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0 };
	float src[10];
	int i;
	my_memcpy(src, arr, 40); //拷贝了10个数,int型占4个字节,则count=4*10
	for (i = 0; i < 10; i++)
	{
		printf("%f ", src[i]);
	}
	printf("\n");
	system("pause");
	return 0;
}

上述代码将arr[10]={1.0,2.0,3.0,4.0,5.0,6.0}复制到src[10]中,运行结果为:

wKioL1ZNnrvRE5-vAAA2lun3x_Q910.png

代码实现memmove函数如下:

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>

void *my_memmove(void *dest, void *src, size_t count)//内存移动,可以内存重叠
{
	assert(dest);
	assert(src);
	char *p1 = (char *)dest;
	char *p2 = (char *)src;
	if ((p1 > p2) && (p1 < p2 + count))
	{
		while (count--)
			*(p1 +count)=*(p2+count);//内存重叠时,从后往前进行拷贝
	}
	else
	{
		while (count--)
		*p1++ = *p2++;//内存不重叠时,从前向后进行拷贝
	}
}

int main()
{
	int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
	int i;
	my_memmove(arr+4, arr+2, 16);//拷贝了4个数,int型占4个字节,则count=4*4
	for (i = 0; i < 10; i++)
		printf("%d ", arr[i]);
	system("pause");
	return 0;
}

上述代码将3,4,5,6复制到5,6,7,8处,运行结果为:1,2,3,4,3,4,5,6,9,10。

实际上,memcpy只是memmove的一个子集。

memccpy()函数的功能也是复制内存,但是如果遇到某个特定值时立即停止复制。

本文出自 “Scen” 博客,请务必保留此出处http://10741357.blog.51cto.com/10731357/1714797

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值