【C语言】内存函数(memcpy)的使用和模拟实现

一、memcpy定义

1.memcpycplusplus中的定义

链接: memcpy
在这里插入图片描述

2.memcpy复制内存块

void * memcpy ( void * destination, const void * source, size_t num );
  • num 字节的值从源指向的位置直接复制到目标指向的内存块。

  • 源指针和目标指针指向的对象的基础类型与此函数无关;结果是数据的二进制副本。

  • 该函数不检查源代码中是否有任何终止null 字符 - 它始终精确地复制 num 字节。

  • 为避免溢出,目标参数和源参数所指向的数组的大小应至少为 num 字节,并且不应重叠(对于重叠的内存块,memmove 是一种更安全的方法)。

3.参数

a.目的地

指向要复制内容的目标数组的指针,类型转换为 void* 类型的指针。

b.源

指向要复制的数据源的指针,类型转换为类型为 const void* 的指针。

c.数字

要复制的字节数。size_t无符号整数类型。

4.函数返回值

函数的返回值类型是无类型指针(void*),它的作用是在函数运行结束后返回拷贝后的目的地内存块的起始地址.

5.函数头文件

该函数包含在头文件<string.h>中.

二、memcpy的使用

使用memcpy()函数完成拷贝整型数组数据

如下,我们使用memcpy()函数将arr1数组的前20字节(即前5个整形)拷贝进arr2中:

分别给memcpy()函数传入3个参数:

目的地址arr2,数据源地址arr1,拷贝字节数

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

查看结果:
在这里插入图片描述
成功的将arr1中的前5个整形的数据拷贝进了arr2的前5个整形空间中.

三、memcpy的模拟实现

思路

  • 1.首先传进函数中的目的地址和源地址指针都不能为NULL如果为NULL的话指针会发生越界访问问题所以在函数开始时用assert断言dstsrc
  • 2.因为我们要按照字节拷贝传进来的数组可能为任意的类型,所以把数据强转为(char*)类型(因为char类型在内存中占用1个字节)
  • 3.因为返回值是目的地址的起始位置的地址,所以我们移动dst指针前要提前记录目的地址的起始位置地址

代码

void * my_memcpy ( void * dst, const void * src, size_t count)
{
 void * ret = dst;
 assert(dst);
 assert(src);
 /*
 * 从低地址向高地址拷贝
 */
 while (count--) {
 *(char *)dst = *(char *)src;
 dst = (char *)dst + 1;
 src = (char *)src + 1;
 }
 return(ret);
}

查看结果

在这里插入图片描述
成功的将arr1中的前20个字节拷贝到了arr2中.

memcpy的弊端

那么接下来我们思考下面这个问题:
当我们的目的地址指针和源地址指针是同一个数组的时候my_memcpy还可以完成我们想要的内存拷贝吗?

※ 如果文章对你有帮助的话,可以点赞收藏!!谢谢支持

  • 25
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C语言中,我们可以模拟实现memcpy函数memcpy函数的原型为void * memcpy(void * destination, const void * source, size_t num),它的作用是将源地址(source)指向的内存块的数据拷贝到目标地址(destination)指向的内存块中,拷贝的字节数由第三个参数num指定。 要实现memcpy函数,我们可以按照以下步骤进行操作: 1. 首先,我们需要创建一个与源内存块相同大小的目标内存块,并将目标内存块的地址保存在destination指针中。 2. 接下来,我们使用一个循环来逐字节地将源内存块的数据复制到目标内存块中,直到拷贝的字节数达到了num的值。 3. 最后,我们返回目标内存块的地址(destination指针),作为函数的返回值。 下面是一个示例的实现代码: ```c void *my_memcpy(void *destination, const void *source, size_t num) { char *dest = (char *)destination; const char *src = (const char *)source; for (size_t i = 0; i < num; i++) { dest[i = src[i]; } return destination; } ``` 在这个实现中,我们将destination和source指针都转换为char类型的指针,这样可以逐字节地进行数据拷贝。然后,我们使用一个循环来逐字节地将源内存块的数据复制到目标内存块中,直到拷贝的字节数达到了num的值。最后,我们返回目标内存块的地址作为函数的返回值。 这样,我们就实现了一个简单的memcpy函数模拟实现。需要注意的是,这只是一个简单的示例实现,实际的memcpy函数可能会有更复杂的实现方式,具体实现可能因编译器和操作系统的不同而有所差异。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一岁就可帅-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值