内存操作函数

一,memcpy的使用和模拟实现

1,memcpy的使用

memcpy为内存拷贝函数,它的声明如下:

void* memcpy (void* destination ,const  void* source, size_t num)

其中两个参数为void*类型,可以用来接收任意类型的数据。 

拷贝方式为:memcpy函数从source开始向后复制num个字节到destination。

注:该函数在遇到‘\0'时,不会停止拷贝。且该函数不支持在数据重叠情况下试用。

int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	memcpy(arr2, arr1, 20);
	for (int i = 0; i < 10; i++)
		printf("%d ", arr2[i]);
}

该程序是将  数组arr1中20个字节数据拷贝到数组arr2中,也就是拷贝5个元素

代码的运行结果是:1 2 3 4 5 0 0 0 0 0

2,memcpy的模拟实现

void* my_memcpy(void* dest, const void* scr, size_t num)
{
	//将scr中num个字节拷贝到dest中
	while (num--)//循环次数
	{
		*(char*)dest = *(char*)scr;//void*类型的指针不能直接进行解引用,故先转换成char*指针,同时char*指针在解引用时,访问一个字节
		dest = (char*)dest+1;//void*类型的指针不能进行+-,故先转换成char*,再加1使指针向后移动
		scr = (char*)scr + 1;
	}
}
int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	my_memcpy(arr2, arr1, 20);
	for (int i = 0; i < 10; i++)
		printf("%d ", arr2[i]);
}

二,memmove的使用和模拟实现

1,memmove的使用

和memcpy相比,memmove函数处理的两个数据可以是重叠的。

 将3,4,5,6,7这5个元素拷贝到1,2,3,4,5

2,memmove的模拟实现

 

 由图可以看出,当dest>scr时,数据需要从前往后拷贝,才能达到效果,若是从后往前拷贝,会使数据被覆盖而达不到想要的效果。那么,当dest<scr时,就需要从后往前拷贝。

模拟实现如下:

 这里,从前往后拷贝时,是和memcpy函数一样的。

三,memset函数

void* memset (void* ptr,int value,size_t num)

memset是内存设置函数,将内存中的值以字节为单位设置成想要的内容,这里的num是以字节为单位的。

使用如下:

int main()
{
	char arr[] = "hello word";
	memset(arr, 'x', 6);
	printf("%s\n", arr);
}

代码结果为xxxxxxword

四,memcpy的使用

int  memcpy(const void*ptr1,const  void* ptr2,size_t num)

比较从ptr1和ptr2开始,向后的num个字节的大小。

 返回值如下:

ptr1<ptr2时,返回小于0的数字;

ptr1=ptr2时,返回0;

ptr1>ptr2时,返回大于0的数字。

 感谢各位的观看,有什么问题还请指教,我会不断学习改进的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值