第二章 内存问题模拟 12
2.1常见内存问题 12
2.2各种内存问题举例 12
2.2.1内存溢出 12
2.2.2内存越界 13
2.2.3内存泄漏 13
2.2.4指针多次释放 14
2.2.5使用已释放的指针 15
2.3main函数返回参数 15
2.3.1返回结构体参数 15
2.3.2直接返回参数 18
注意:
/* 每种demo都是参考别的博客写的,且每种内存问题范例可以多样化不拘泥这一种,比如内存泄漏:各种写法都可以造成泄漏,这里我只举出其中一种内存泄漏;所以我所举的范例都是片面的,不全,如果只针对简单的模拟内存问题的demo,还是勉强可以用上的。 */
第二章 内存问题模拟
2.1常见内存问题
首先,比较常见的内存问题有下面几种:
memory overrun:写内存越界
double free:同一块内存释放两次
use after free:内存释放后使用
wild free:释放内存的参数为非法值
access uninitialized memory:访问未初始化内存
read invalid memory:读取非法内存,本质上也属于内存越界
memory leak:内存泄露
use after return:caller访问一个指针,该指针指向callee的栈内内存
stack overflow:栈溢出
2.2各种内存问题举例
2.2.1内存溢出
/********************************************************
非法内存操作:
结构体成员指针未初始化
没有为结构体指针分配足够的内存
*********************************************************/
struct Demo
{
int* p;
};
void illegal_memory_operation(void)
{
struct Demo d1;
struct Demo d2;
int i = 0;
for(i=0; i<10; i++)
{
d1.p[i] = 0; // 指针未初始化
}
d2.p = (int*)calloc(5, sizeof(int));
for(i=0; i<10; i++)
{
d2.p[i] = i; // 没有分配足够的