linux - 为什么某个进程会多次加载 lib?

标签 linux memory-management loadlibrary shared-libraries pmap

b7f27000     84K r-x--  /lib/libpthread-2.5.so
b7f3c000      4K -----  /lib/libpthread-2.5.so
b7f3d000      4K r----  /lib/libpthread-2.5.so
b7f3e000      4K rw---  /lib/libpthread-2.5.so
b7f3f000      8K rw---    [ anon ]
b7f41000     88K r-x--  /lib/libselinux.so.1
b7f57000      8K rw---  /lib/libselinux.so.1
b7f59000    256K r-x--  /usr/lib/libncurses.so.5.5
b7f99000     32K rw---  /usr/lib/libncurses.so.5.5
b7fa1000      8K rw---    [ anon ]
b7fa3000      4K r----  /usr/lib/locale/en_US.utf8/LC_MESSAGES/SYS_LC_MESSAGES
b7fa4000      4K r----  /usr/lib/locale/en_US.utf8/LC_PAPER
b7fa5000      4K r----  /usr/lib/locale/en_US.utf8/LC_NAME
b7fa6000      4K r----  /usr/lib/locale/en_US.utf8/LC_ADDRESS
b7fa7000      4K r----  /usr/lib/locale/en_US.utf8/LC_TELEPHONE
b7fa8000      4K r----  /usr/lib/locale/en_US.utf8/LC_MEASUREMENT
b7fa9000      4K r----  /usr/lib/locale/en_US.utf8/LC_IDENTIFICATION
b7faa000    108K r-x--  /lib/ld-2.5.so
b7fc5000      4K r----  /lib/ld-2.5.so
b7fc6000      4K rw---  /lib/ld-2.5.so
bf96f000    228K rw---    [ stack ]
 total    23740K

为什么这些so lib加载的时间比more time还多?需要吗?为什么?

最佳答案

实际上,每个库只加载一次;您看到的是每个库使用的多个内存区域

库包含代码、rodata 和数据 (+bss)。代码是只读和可执行的(r-x),rodata是只读的(r--),数据(和bss)是可读写的(rw-)。这些是您正在查看的内存段(请注意,它们都有不同的内存保护标志和大小)。并非所有库都具有所有这些段,因此您会看到一些库仅映射了两个(甚至一个)内存区域。

请注意,pmap 的“总”输出仅测量虚拟内存利用率(即使对于小进程,它也可能非常高)。对于物理内存使用,请使用 pmap -x 并查看 RSS(驻留集大小)。

关于linux - 为什么某个进程会多次加载 lib?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12524500/

相关文章:

matlab - 在matlab代码中使用dll文件

c++ - 尝试执行文件时出现 "sh: ./<file> not found"错误

linux - Debian 包控制文件问题

python在centos上更新到2.7.13

linux - 如何在 Linux 中处理多个 SIGSEGV 事件?

c# - DllImport vs LoadLibrary,最好的方法是什么?

android - UVC相机错误: registerNativeMethods: class'com/serenegiant/usb/UVCCamera' not found

linux - Fedora lobpcre.so.0

ios - 尽管不使用 Core Plot,但核心动画无法分配字节

C (std=c99) 指向结构内存分配的指针