C、C++常见内存操作问题 内存溢出 内存泄漏 内存越界 缓冲区溢出

常见内存操作问题

常见内存操作问题,本文简单整理了内存溢出(out of memory), 内存泄露(memory leak),内存越界,缓冲区溢出(buffer overflow)方面的信息。


1、内存溢出out of memory

内存溢出out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,出现out of memory。
如malloc new等操作。

2、内存泄露memory leak

内存泄露memory leak,是指程序在申请内存后,无法释放已申请的内存空间;内存泄露堆积后果就是用光内存,出现out of memory。
如malloc操作后,没有free;new操作后没有delete。

3、内存越界

向系统申请了一块内存,而在使用内存时,超出了申请的范围(常见的有使用特定大小数组时发生内存越界)。
C对于数组指针引用不进行任何边界检查,且局部变量和状态信息都存放在栈中。对越界的数组元素的写操作会破坏存储在栈中的状态信息。当程序使用这个被破坏的状态,试图重新加载寄存器或执行ret指令,就会出现严重的错误。
内存越界一般不引起编译器的警觉,会在运行阶段产生莫名其妙的后果,或者越得较严重的被操作系统捕捉到,而进行处理(弹出对话框并结束该进程)。

如下代码:
char str[] = “Hello World!”;
char buf[10] = {0};
strcpy(buf, str); //out of buffer space
将str字符串中的字符(含空格)复制到只能容纳下10个字符的buf数组中,结果导致内存越界。

3.1 内存越界与内存溢出的区别

内存越界在使用系统提供的内存时,做了一些超出申请的内存范围的操作;内存溢出是在申请内存大小时就已超出系统能提供的。

4、缓冲区溢出buffer overflow

程序在运行过程中,为了临时存取数据(用户输入数据、程序临时数据)的需要,一般都要分配一些内存空间(存储位置:Stack(栈)、Heap(堆)、数据段),通常称这些空间为缓冲区(其本质:数组)。如果向缓冲区中写入超过其本身长度的数据,以致于缓冲区无法容纳,就会造成缓冲区以外的存储单元被改写,这种现象就称为缓冲区溢出。
当计算机向缓冲期内填充数据位数时,超过了缓冲区本身的容量,溢出的数据覆盖在合法数据上。往往会引发不可预料的后果。
操作系统所使用的缓冲区又被称为“堆栈”。在各个操作进程之间,指令会被临时存储在“堆栈”当中,“堆栈”也会出现缓冲区溢出。
缓冲区溢出类型有:栈溢出(缓冲区在栈中分配)、堆溢出(缓冲区在栈中分配)。

4.1 内存越界和缓冲区溢出的区别

越界访问,是编程粗心造成的,是被动的,没有恶意。
缓冲区溢出,是一种攻击手段,是主动的,恶意的。

4.2 缓冲区溢出的原因

(1) 在C语言中,指针和数组越界是Buffer overflow的根源。而且,在C语言标准库中就有许多能提供溢出的函数,如strcat(),strcpy(),sprint(),vsprintf(),bcopy(),gets()和scanf()。
(2) 通过指针填充数据。
(3) 不好的编程习惯。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

hgggg2003

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

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

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

打赏作者

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

抵扣说明:

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

余额充值