如何查看Linux上程序或进程用到的库

如何查看Linux上程序或进程用到的库,第1张

使用ldd命令,可以查看程序使用的动态共享库文件:

比如查询amixer使用的动态共享库文件:

ldd /usr/bin/amixer

linux-vdso.so.1 => (0x00007ffcab5ad000)

libm.so.6 =>/lib/x86_64-linux-gnu/libm.so.6 (0x00007fd7317f0000)

libasound.so.2 =>/usr/lib/x86_64-linux-gnu/libasound.so.2 (0x00007fd731500000)

libc.so.6 =>/lib/x86_64-linux-gnu/libc.so.6 (0x00007fd73113b000)

libdl.so.2 =>/lib/x86_64-linux-gnu/libdl.so.2 (0x00007fd730f37000)

libpthread.so.0 =>/lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fd730d19000)

librt.so.1 =>/lib/x86_64-linux-gnu/librt.so.1 (0x00007fd730b11000)

/lib64/ld-linux-x86-64.so.2 (0x00007fd731af6000)

Linux系统提供了复杂的存储管理系统,使得进程所能访问的内存达到4GB。在Linux系统中,进程的4GB内存空间被分为两个部分——用户空间与内核空间。用户空间的地址一般分布为0~3GB(即PAGE_OFFSET,在Ox86中它等于OxC0000000),这样,剩下的3~4GB为内核空间,用户进程通常只能访问用户空间的虚拟地址,不能访问内核空间的虚拟地址。用户进程只有通过系统调用(代表用户进程在内核态执行)等方式才可以访问到内核空间。每个进程的用户空间都是完全独立、互不相干的,用户进程各自有不同的页表。而内核空间是由内核负责映射,它并不会跟着进程改变,是固定的。内核空间的虚拟地址到物理地址映射是被所有进程共享的,内核的虚拟空间独立于其他程序。Linux中1GB的内核地址空间又被划分为物理内存映射区、虚拟内存分配区、高端页面映射区、专用页面映射区和系统保留映射区这几个区域。对于x86系统而言,一般情况下,物理内存映射区最大长度为896MB,系统的物理内存被顺序映射在内核空间的这个区域中。当系统物理内存大于896MB时,超过物理内存映射区的那部分内存称为高端内存(而未超过物理内存映射区的内存通常被称为常规内存),内核在存取高端内存时必须将它们映射到高端页面映射区。Linux保留内核空间最顶部FIXADDR_TOP~4GB的区域作为保留区。当系统物理内存超过4GB时,必须使用CPU的扩展分页(PAE)模式所提供的64位页目录项才能存取到4GB以上的物理内存,这需要CPU的支持。加入了PAE功能的Intel Pentium Pro及以后的CPU允许内存最大可配置到64GB,它们具备36位物理地址空间寻址能力。由此可见,对于32位的x86而言,在3~4GB之间的内核空间中,从低地址到高地址依次为:物理内存映射区隔离带vmalloc虚拟内存分配器区隔离带高端内存映射区专用页面映射区保留区。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7185641.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存