为什么说内存泄露是个大麻烦?
本人在校大学生,接触的东西不是很多,看见很多人在讨论内存泄露的事情,想起老师说的话:一个new配一个delete,一个malloc配一个free就行了,就觉得很奇怪。难道说遵从以上规则编写程序,还会存在内存泄露吗?求指教!
[解决办法]
等你写的程序大一点,要多人合作时,你要能遵从得了才叫碰鬼了呢。
[解决办法]
关键是有的时候在一个模块中new,需要在其它的模块中delete
或者有的时候由于程序运行逻辑的问题,delete的那部分程序没有被执行
除了new/delete,GDI资源等等也会造成内存泄露
在pc上还好,如果是在wince嵌入式操作系统上
内存本来就很小,总共就几十M,除去系统占用的,没剩多少了
如果你的app存在泄露的话,会运行的越来越慢,甚至卡死
[解决办法]
等你写的程序大一点,要多人合作时,你要能遵从得了才叫碰鬼了呢。
[解决办法]
有些内存泄露十分隐蔽,所以很烦人。
[解决办法]
根指针相关的内存泄露有很多种,不一定都是因为new/delete不匹配造成的,你们老师那样说是因为其接触实际代码量还不够多的缘故。
最常见的内存泄露出现在结构或类赋值,导致孤指针存在,使内存无法释放,例如:
struct T{
A *dat;
int n;};
T a={new A,20},b={0,0}; a=b; //--内存泄露了
char *s1="...",*s2= new char[256]; s2=s1; //-- 内存泄露了
char *s1=new char[40], *s2=new char[80]; strcpy(s1,s2) //- 内存超界泄露了
char *s1=new char[40],*s2="dfek dkr l kre";memset(s1,0x3c,40);strcat(s1,s2);//-内存超界泄露了
[解决办法]
内存泄漏会因为减少可用内存的数量从而降低计算机的性能。最终,在最糟糕的情况下,过多的可用内存被分配掉导致全部或部分设备停止正常工作,或者应用程序崩溃。
内存泄漏可能不严重,甚至能够被常规的手段检测出来。在现代操作系统中,一个应用程序使用的常规内存在程序终止时被释放。这表示一个短暂运行的应用程序中的内存泄漏不会导致严重后果。
在以下情况,内存泄漏导致较严重的后果:
* 程序运行后置之不理,并且随着时间的流失消耗越来越多的内存(比如服务器上的后台任务,尤其是嵌入式系统中的后台任务,这些任务可能被运行后很多年内都置之不理)
* 新的内存被频繁地分配,比如当显示电脑游戏或动画视频画面时
* 程序能够请求未被释放的内存(比如共享内存),甚至是在程序终止的时候
* 泄漏在操作系统内部发生
* 泄漏在系统关键驱动中发生
* 内存非常有限,比如在嵌入式系统或便携设备中
* 当运行于一个终止时内存并不自动释放的操作系统(比如AmigaOS)之上,而且一旦丢失只能通过重启来恢复。
[解决办法]
(7) 动态检查,使用purify和valgrind等工具进行检查
不过,编程的基本功才是最关键的,才是防止内存泄漏的真谛。苦练多思考,扎实语言的基础