1
2
3
4
void doSomething()
{
int *pnValue = new int;
}
此函数分配一个整数动态,但从来没有让它使用删除。因为指针遵循正态变量,函数结束时,pnvalue将超出范围。因为pnvalue是唯一的变量的动态分配的整数地址,当pnvalue破坏没有指向动态分配的内存。这就是所谓的内存泄漏。作为一个结果,动态分配的整数不能删除,从而不能被重新分配或重新。内存泄漏吃免费的内存运行程序时,使更少的内存不仅可以对这一计划,但其他的程序以及。严重的内存泄漏问题的方案,可以吃所有可用的内存,导致整个机器运行缓慢甚至崩溃。
内存泄漏也如果指针的动态分配的内存地址重新分配到另一个值的结果:
1
2
3
int nValue = 5;
int *pnValue = new int;
pnValue = &nValue; // old address lost, memory leak results
1
2
int *pnValue = new int;
pnValue = new int; // old address lost, memory leak results
返回的地址从第二配置覆盖第一分配地址。因此,第一分配成为一个内存泄漏!
空指针(第二部分)
空指针(指针设置为解决0)特别有用,在处理动态内存分配。一个空指针说“没有记忆已分配但”。这允许我们做的事情一样,有条件的分配内存:
|