初学者该如何熟悉Linux内存管理
中分配的、大小任意的(内存块的大小可以在程序运行期决定)、使用完后![]() ![]() 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.
|