memcpy 内存越界分析

memcpy 内存越界

  • 本文主要分析memcpy为什么会导致内存越界,在什么场景下会导致越界,为什么memcpy越界之后并没有必现coredump

memcpy 源码


void *memcpy(void *dst, const void *src, size_t len)
{  
    if(NULL == dst || NULL == src){  
        return NULL;  
    }  
    void *ret = dst;  
    if(dst <= src || (char *)dst >= (char *)src + len){  
        //没有内存重叠,从低地址开始复制  
        while(len--){  
            *(char *)dst = *(char *)src;  
            dst = (char *)dst + 1;  
            src = (char *)src + 1;  
        }  
    }else{  
        //有内存重叠,从高地址开始复制  
        src = (char *)src + len - 1;  
        dst = (char *)dst + len - 1;  
        while(len--){  
            *(char *)dst = *(char *)src;  
            dst = (char *)dst - 1;  
            src = (char *)src - 1;  
        }  
    }  
    return ret;  
}

一个简单的实例

  • 代码

#include <string>
#include <string.h>
#include <iostream>
using namespace std;

int main()
{
    string s = "testmemcpy";
    int string_len = s.length();
    {
        char buf[5];
        memcpy(buf, s.c_str(), string_len);
        cout << buf << endl;
        cout << s << endl;
    }
    return 0;
}
  • 编译
    g++ main.cpp -std=c++11 -o main
  • 运行
    ./main
  • 结果
testmemcpy�4}��qv�
testmemcpy
*** stack smashing detected ***: ./ttt terminated
Aborted (core dumped)

分析

源码分析

  • 函数申明
    void *memcpy(void *dst, const void *src, size_t len)
  • 参数
dst		目标地址
src		源地址
len		从源地址拷贝的长度
  • 分析,从没有内存重叠的拷贝
1.    while(len--){  
2.        *(char *)dst = *(char *)src;  
3.        dst = (char *)dst + 1;  
4.        src = (char *)src + 1;  
5.    }
* 从源码来看,拷贝的长度只是关心len的长度,所以会造成两个问题
* 1. src的内存长度小于len,这就会造成源地址src已经产生内存越界
* 2. dst的内存长度小于len,这就会造成目标地址dst产生内存越界

结论

  • memcpy内存越界并不总是会coredump的,内存越界只是使用了并非自己的内存,会造成内存乱掉。在释放的时候,如果越界的内存已经被释放,就会导致coredump了
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值