linux 查看动态库?linux怎么查看文件内容

查看linux当前加载库文件的命令

ldd<可执行文件名>查看可执行文件链接了哪些系统动态链接库

nm<可执行文件名>查看可执行文件里面有哪些符号

strip<可执行文件名>去除符号表可以给可执行文件瘦身

如果我们想从可执行程序里面提取出来一点什么文本信息的话,还可以用strings命令

strings<可执行文件名>

Linux操作系统上面的动态共享库大致分为三类:

1、操作系统级别的共享库和基础的系统工具库

比方说libc.so, libz.so, libpthread.so等等,这些系统库会被放在/lib和/usr/lib目录下面,如果是64位操作系统,还会有/lib64和/usr/lib64目录。如果操作系统带有图形界面,那么还会有/usr/X11R6/lib目录,如果是64位操作系统,还有/usr/X11R6/lib64目录。此外还可能有其他特定Linux版本的系统库目录。

这些系统库文件的完整和版本的正确,确保了Linux上面各种程序能够正常的运行。

2、应用程序级别的系统共享库

并非操作系统自带,但是可能被很多应用程序所共享的库,一般会被放在/usr/local/lib和/usr/local/lib64这两个目录下面。很多你自行编译安装的程序都会在编译的时候自动把/usr/local/lib加入gcc的-L参数,而在运行的时候自动到/usr/local/lib下面去寻找共享库。

以上两类的动态共享库,应用程序会自动寻找到他们,并不需要你额外的设置和担心。这是为什么呢?因为以上这些目录默认就被加入到动态链接程序的搜索路径里面了。Linux的系统共享库搜索路径定义在/etc/ld.so.conf这个配置文件里面。这个文件的内容格式大致如下:

/usr/X11R6/lib64

/usr/X11R6/lib

/usr/local/lib

/lib64

/lib

/usr/lib64

/usr/lib

/usr/local/lib64

/usr/local/ImageMagick/lib

假设我们自己编译安装的ImageMagick图形库在/usr/local/ImageMagick目录下面,并且希望其他应用程序都可以使用 ImageMagick的动态共享库,那么我们只需要把/usr/local/ImageMagick/lib目录加入/etc/ld.so.conf文件里面,然后执行:ldconfig命令即可。

ldcofig将搜索以上所有的目录,为共享库建立一个缓存文件/etc/ld.so.cache。为了确认ldconfig已经搜索到ImageMagick的库,我们可以用上面介绍的strings命令从ld.so.cache里面抽取文本信息来检查一下:

strings/etc/ld.so.cache| grep ImageMagick

输出结果为:

/usr/local/ImageMagick/lib/libWand.so.10

/usr/local/ImageMagick/lib/libWand.so

/usr/local/ImageMagick/lib/libMagick.so.10

/usr/local/ImageMagick/lib/libMagick.so

/usr/local/ImageMagick/lib/libMagick++.so.10

/usr/local/ImageMagick/lib/libMagick++.so

已经成功了!

3、应用程序独享的动态共享库

有很多共享库只被特定的应用程序使用,那么就没有必要加入系统库路径,以免应用程序的共享库之间发生版本冲突。因此Linux还可以通过设置环境变量LD_LIBRARY_PATH来临时指定应用程序的共享库搜索路径,就像我们上面举的那个例子一样,我们可以在应用程序的启动脚本里面预先设置 LD_LIBRARY_PATH,指定本应用程序附加的共享库搜索路径,从而让应用程序找到它。

linux下查看编译的静态库和动态库是32位还是64位

了解如何在Linux下确认编译出的静态库和动态库是32位还是64位,对确保软件兼容性和运行环境至关重要。以下步骤将帮助您完成这一任务。

首先,使用`file`指令来快速查看动态库的位数。例如,通过运行`file libcurl.so`,您可以获取到库文件的类型,从而判断其是32位还是64位。这种方法提供了一种直观的识别方式,适用于初步筛选。

若想深入了解静态库的位数,则需使用`objdump-a`指令。通过命令`objdump-a libtest.a`,可以详细查看静态库的构成,包括其位数。这一步骤提供了更深入的技术洞察,对于库内部结构的分析尤为有用。

对于动态库的全面信息获取,推荐使用`readelf-h`指令。以`readelf-h libssl.so`为例,此命令不仅显示库文件是32位还是64位,还提供了其他重要信息,如编译平台、运行平台等。Class字段和Machine字段共同揭示了库的位数和目标运行环境,是进行深入分析的最佳工具。

综上所述,通过运用`file`、`objdump-a`和`readelf-h`这三个强大命令,您能有效地判断Linux下编译的静态库和动态库是32位还是64位。这些技巧对于确保软件在多变的环境配置中正常运行至关重要。

linux动态库调用动态库linux动态库的调用

如何更新linux系统动态链接库/usr/local/lib/usr/lib?

可以放在当前目录下,但是要设置一下库文件的路径:LD_LIBRARY_PATH=./:/usr/local/pet20/lib:/lib/:/usr/local/libexportLD_LIBRARY_PATH这样,在调用的时候就会自动从当前目录找。

如果是显式调用则不用,只要在程序里指定.so的文件路径就可以了。所以放在当前目录下也是没问题的。

linux下C/C++动态库在运行时是怎样加载进来的?

你说的程序应该是采用了dynamicloading

实际上调用了这样一组接口:

dlopendlclosedlsym函数名被作为参数传递进去,交给动态链接器ld.so。随后ld.so会在已经加载的动态库中查找与函数名匹配的符号。如果查找成功就可以返回一个地址指向这个符号的地址。对于函数,这个地址就相当于是一个函数指针。而这整个过程可以顺利进行下去,还要依赖于当前程序与动态库的ABI

如何在linux平台生成静态链接库与动态链接库?

动态库和静态库

在Win下,动态库以.dll结尾,静态库以.lib结尾。

在Linux下,动态库文件以.so结尾,静态库以.a结尾。

在Mac下,动态库以.dylib结尾,静态库以.a结尾。

动态库的优势和劣势

动态函数库在编译的时候并没有被编译进目标代码中,你的程序执行到相关函数时才调用该函数库里的相应函数,因此动态函数库所产生的可执行文件比较小。由于函数库没有被整合进你的程序,而是程序运行时动态的申请并调用,所以程序的运行环境中必须提供相应的库。动态函数库的改变并不影响你的程序,所以动态函数库的升级比较方便。

某个程序在运行时要调用某个动态链接库函数的时候,OS首先查看所有正在运行的进程,找找看是否已经有人载入了这个库。如果有的话,直接用。如果没有才会载入。这样的第一个优点就是节省内存空间。动态调入意味着是等需要的时候才调入内存,而不是不管用不用都要先放到内存里来。

我如果想要升级某个软件。如果升级的位置是在dll里,那软件其他的部位不需要重新编译链接。所以升级方便。

静态库的优势和劣势

利用静态函数库编译成的文件比较大,因为整个函数库在编译时都会被整合进目标代码中,他的优点就显而易见了,即编译后的执行程序不需要外部的函数库支持,因为所有使用的函数都已经被编译进去了。当然这也会成为他的缺点,因为如果你静态链接的函数库改变了,那么你的程序必须重新编译。

代码更精简,因为不必做版本检查。

程序分发时文件个数少,因为静态链接到源文件里了。

只编译进来库中所用的部分,而不用整个库。

生成的binary占空间更大。

重复的库可能出现在多个进程,浪费内存。

库内部更新的话需要重新编译binary。

Linux平台的静态库

静态库的生成静态库的链接

Linux平台的动态库

动态库的生成动态库的链接

Windows平台的静态库

静态库的生成/MT使用LIBCMT.lib编译以创建多线程可执行文件。生成静态库lib。r静态库的链接

1、在使用链接库的代码开头加入,第二行是要调用的链接库里的函数:

2、将要调用的链接库的lib放入项目源代码中,然后编译。(编译的时候不需要dll。这里把静态部分lib编译进了exe,但动态库dll还没用。)

3、运行之前要把dll放到exe目录下。

Windows平台的动态库

动态库的生成/MD使用MSVCRT.lib编译以创建多线程DLL。生成动态库。r动态库的链接

1、LoadLibrary(或MFC的AfxLoadLibrary),装载动态库。

2、GetProcAddress,获取要引入的函数,将符号名或标识号转换为DLL内部地址。

3、FreeLibrary(或MFC的AfxFreeLibrary),释放动态链接库。

qtcreator怎么加载大量windows下的动态库?

.pro文件管理,所以库文件要在.pro文件中添加。

1.添加库文件静态库linux:LIBS+=your_lib_path/your_lib动态库linux:LIBS+=-Lyour_lib_path-lyour_lib//经过测试了win32:LIBS+=your_lib_path/your_lib例如:LIBS+=-Llib/pcsc/-lpcscliteLIBS+=lib/pcsc/libpcsclite.a

2.添加头文件INCLUDEPATH+=your_include_path例如:INCLUDEPATH+=./usr/local/include(点号后面有空格)

3.添加要编译的源文件和头文件SOURCES:所有源文件列表HEADERS:所有头文件列表FORMS:所有.ui文件列表前期工作:1.检查gcc,g++,qmake是否用错。2.在Makefile中检查是否少了头文件3.检查是否与错用了

4.需要另外加库的程序最好单独建一个文件

linuxc编程调用系统的动态库时,要使用dlopen等函数吗?

linux调用库的方式有三种:

1.静态链接库

2.动态链接库

3.动态加载库

其中1,2都是在编程时直接调用,在链接时加参数-l进行链接

第三种需要在编程时使用dlopen等函数来获取库里面函数的定义,然后进行调用.

不过对于没有提供头文件的动态库,只能dlopen等函数来调用

阅读剩余
THE END