模拟实现内存操作函数memcpy、memmove

本文介绍了如何模拟实现C语言中的memcpy与memmove函数。memcpy用于简单地从源地址复制数据到目标地址,而memmove则能处理源与目标重叠的情况。文中提供了具体的代码示例,展示了这两种函数的工作原理。

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

1、模拟实现memcpy
memcpy是内存拷贝函数,功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。
函数原型为:void *memcpy(void *dest, const void *src, size_t n);

void *my_memcpy(void *dst, const void *src, size_t count)
{
    void *ret = dst;
    while (count--){
        *(char *)dst = *(char *)src;
        dst = (char *)dst + 1;
        src = (char *)src + 1;
    }
    return ret;
}
int main()
{
    char arr1[] = "welcome to word";
    char arr2[] = "123456";
    printf("%s\n",my_memcpy(arr1, arr2, 3));
    system("pause");
    return 0;
}

2、模拟实现memmove
memmove是一个内存操作函数,不是字符串操作函数,它可以处理多种类型的数据。用于从src拷贝count个字节到dest,如果目标区域和源区域有重叠的话,memmove能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中。但复制后src内容会被更改。但是当目标区域与源区域没有重叠则和memcpy函数功能相同。
函数原型:void memmove( void dest, const void* src, size_t count );

//1、它的返回值是void*,参数类型也是void*,这样它才可以处理不同类型的数据。
//2、目标dest不能加const,源src加const。原因是我们需要从源src中拷贝数据到dest中,需要对dest进行赋值。若用const保护                                              
//dest,便不能完成赋值操作。
#include<stdio.h>
#include<assert.h>

void *my_memmove(void *dest, const void *src, size_t count)
{
    void *ret = dest;

    if (dest <= src || (char *)dest >= ((char *)src + count))
    {
        while (count--)
        {
            *(char *)dest = *(char *)src;
            dest = (char *)dest + 1;
            src = (char *)src + 1;
        }
    }
    else
    {
        dest = (char *)dest + count - 1;
        src = (char *)src + count - 1;
        while (count--)
        {
            *(char *)dest = *(char *)src;
            dest = (char *)dest - 1;
            src = (char *)src - 1;
        }
    }
    return ret;
}
int main()
{
    char arr1[] = "abcd1234";
    char arr2[] = "hello word";
    printf("%s\n", my_memmove(arr1, arr2, 5));
    system("pause");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值