初学者该如何熟悉Linux内存管理
中分配的、大小任意的(内存块的大小可以在程序运行期决定)、使用完后显示释放的内存.应用程序一般使用malloc、realloc、new等函数从堆中分配到一块内存,使用完后,程序负责相应的调用free或delete释放该内存块.否则,这块内存就不能被再次使用,我们就说这块内存泄漏了.
2.内存泄露的危害 从用户使用程序的角度来看,内存泄漏本身不会产生什么危害.作为一般的用户,根本感觉不到内存泄漏的存在.真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存.从这个角度来说,一次性内存泄漏并没有什么危害,它不会堆积.而隐式内存泄漏危害性则非常大,较之于常发性和偶发性内存泄漏它更难被检测到.存在内存泄漏问题的程序除了会占用更多的内存外,还会使程序的性能急剧下降.对于服务器而言,如果出现这种情况,即使系统不崩溃,也会严重影响使用. 3.内存泄露的检测和回收 对于内存溢出之类的麻烦,大家可能在编写指针比较多的复杂程序时就会遇到.在 Linux或Unix下,C和C 语言是最常使用的工具.但是C 程序缺乏相应的手段来检测内存信息,只能使用top指令观察进程的动态内存总额.程序退出时,我们无法获知任何内存泄漏信息. (1)使用Linux命令回收内存,可以使用ps、kill两个命令检测内存使用情况和进行回收.在使用超级用户权限时使用命令“ps”,它会列出所有正在运行的程序名称和对应的进程号(PID).kill命令的工作原理是向Linux 操作系统的内核送出一个系统操作信号和程序的进程号(PID).
下面举例说明,为了高效率回收内存可以使用命令ps参数v: #ps v PID TTY STAT TIME MAJFL TRS DRS RSS %MEM COMMAND 2530 vc/1 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty1 2531 vc/2 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty2 2532 vc/3 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty3 2533 vc/4 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty4 2534 vc/5 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty5 2535 vc/6 S 0:00 104 6 1325 408 0.1 /sbin/mingetty tty6 2639 pts/1 S 0:00 545 16 2643 968 0.3 [su] 2684 pts/1 S 0:00 361 586 2501 1592 0.6 bash 2711 pts/0 S 0:00 545 16 2643 968 0.3 [su] 2714 pts/0 S 0:00 361 586 2501 1592 0.6 bash 2754 pts/2 S 0:00 545 16 2643 968 0.3 [su] 2757 pts/2 S 0:00 361 586 2501 1592 0.6 bash 2818 pts/1 S 0:00 120 29 1478 480 0.1 ping 192.168.1.7 2939 pts/2 R 0:00 156 58 2469 644 0.2 ps -v 如果想回收ping命令的内存的话,可以使用下面命令: # kill -9 2818 (2)使用工具软件 Memprof是一个非常具有吸引力且易于使用的软件,它由Red Hat的Owen Talyor创立.这个工具用于GNOME前端的Boehm-Demers-Weiser垃圾回收器.这个工具直接就可以执行,并且其工作起来无需对源代码进行任何修改.在程序执行时,这个工具会以图形化的方式显示内存的使用情况,工作界面见图2. http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |