nm和ldd用法

前言

经常使用静态库和动态库的接口,有时候可以查看是否包含了哪些函数等,或可以查看某一库的依赖是否链接,是否包含。


1. 查看某个目标文件(.so/.a/.out)是否包含某个接口函数

nm -Au bar.a(foo.so/foo.out) |grep "function" 
-A 每行或显示全路径名称或显示对象库名
-u 未定义符号
function 需要查看的符号(函数,全局变量等)				

2. 查看某个动态库依赖的链接

linux-vdso.so.1 (0x0000007f8e252000)
	libc.so.6 => /lib/aarch64-linux-gnu/libc.so.6 (0x0000007f8d9a7000)
	/lib/ld-linux-aarch64.so.1 (0x0000007f8e226000)

3. 查看某个可执行文件是否已链接到对应的库

linux-vdso.so.1 (0x0000007f88054000)
	libmem_manager.so => not found
	libpthread.so.0 => /lib/aarch64-linux-gnu/libpthread.so.0 (0x0000007f87f12000)
	libstdc++.so.6 => /usr/lib/aarch64-linux-gnu/libstdc++.so.6 (0x0000007f87d7e000)
	libgcc_s.so.1 => /lib/aarch64-linux-gnu/libgcc_s.so.1 (0x0000007f87d5a000)
	libc.so.6 => /lib/aarch64-linux-gnu/libc.so.6 (0x0000007f87c01000)
	/lib/ld-linux-aarch64.so.1 (0x0000007f88028000)
	libm.so.6 => /lib/aarch64-linux-gnu/libm.so.6 (0x0000007f87b48000)

libmem_manager.so库未指定链接, 说明没有讲库的路径加载到环境变量, 在shell中执行如下即可

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:“libmem_manager.so所在的绝对目录”
<think>嗯,用户现在问的是关于Qt使用DLLLIB动态库的问题。之前他们遇到了读取配置文件失败的问题,现在转向动态库的使用,可能是在项目开发中需要集成第三方库或者模块化自己的代码。我需要先理清楚Qt中如何处理动态链接库,包括Windows下的DLLLinux下的so文件,以及静态库动态库的区别。 首先,用户可能想知道如何在Qt项目中正确链接使用动态库。应该分步骤讲解,比如准备库文件、头文件包含、项目配置(.pro文件)、动态库的部署等。要考虑到不同操作系统下的差异,特别是WindowsLinux的不同处理方式。 然后,用户可能在实际操作中遇到常见问题,比如运行时找不到DLL,或者符号解析错误。这时候需要给出排查方法,比如使用Dependency Walker检查依赖,或者Linux下的ldd命令。还要提醒用户注意动态库的构建方式是否与Qt项目兼容,比如编译器版本、架构(32/64位)是否匹配。 另外,静态库动态库的区别也是关键点。需要简明扼要地解释两者的优缺点,帮助用户根据项目需求选择合适的方式。可能还要提到Qt自身的机制,比如插件系统或者QPluginLoader类,这些是否与动态库的使用相关。 需要检查之前的对话历史,用户之前遇到的是配置文件问题,现在转向动态库,可能他们的项目在扩展功能,需要引入外部库,所以实际应用场景可能是调用第三方功能或者模块化开发。这时候要给出具体的代码示例,比如如何在代码中显式或隐式加载库,如何调用其中的函数,特别是处理C++的name mangling问题,建议使用extern "C"或者统一的编译器设置。 另外,要注意动态库的导出符号,特别是在Windows下需要使用__declspec(dllexport)__declspec(dllimport),而在Linux下则通过可见性属性来控制。这部分可能需要提供示例代码,说明如何在创建动态库时正确导出类或函数。 最后,部署时的注意事项也很重要,比如确保动态库位于正确的路径,或者如何打包应用程序以便用户环境可以找到这些库。可能还需要提到设置环境变量,如Windows的PATH,Linux的LD_LIBRARY_PATH,或者macOS的DYLD_LIBRARY_PATH。 总结下来,回答的结构应该包括基本概念、使用步骤(准备、包含头文件、配置.pro文件、部署)、不同操作系统的处理、常见问题及解决方案,以及静态库动态库的对比。需要确保语言通俗易懂,步骤清晰,并给出代码示例命令示例,帮助用户快速上手解决问题。</think>在Qt中使用动态库(DLL/LIB)涉及三个核心环节:**编译链接**、**运行时加载****跨平台适配**。以下是具体实现方法注意事项: --- ### 一、动态库类型对比 | 类型 | 扩展名 | 优点 | 缺点 | |------------|--------------|------------------------|------------------------| | 静态库 | `.a`(Unix) `.lib`(Win) | 无需额外部署 | 增大可执行文件体积 | | 动态库 | `.so`(Unix) `.dll`(Win)| 节省内存,便于更新 | 需要正确部署依赖 | --- ### 二、动态库创建(以Windows为例) #### 1. 创建导出宏 ```cpp // mylibrary_global.h #ifdef MYLIBRARY_LIB #define MYLIB_EXPORT __declspec(dllexport) #else #define MYLIB_EXPORT __declspec(dllimport) #endif ``` #### 2. 实现导出类/函数 ```cpp // mathlib.h #include "mylibrary_global.h" class MYLIB_EXPORT MathLib { public: static double add(double a, double b); }; // mathlib.cpp double MathLib::add(double a, double b) { return a + b; } ``` #### 3. pro文件配置 ```qmake # 生成动态库的关键配置 TEMPLATE = lib CONFIG += shared DEFINES += MYLIBRARY_LIB # 仅在构建库时定义 ``` --- ### 三、动态库调用方式 #### 方式1:隐式链接(推荐) **步骤:** 1. 将`.lib`文件放入项目目录 2. 在.pro文件中添加: ```qmake LIBS += -L$$PWD/libs -lMathLib INCLUDEPATH += $$PWD/include ``` 3. 代码调用: ```cpp #include "mathlib.h" double result = MathLib::add(3.14, 2.718); ``` #### 方式2:显式加载(QLibrary) ```cpp QLibrary myLib("MathLib.dll"); if(myLib.load()) { typedef double (*AddFunc)(double, double); AddFunc add = (AddFunc)myLib.resolve("add"); if(add) { double result = add(3.14, 2.718); } myLib.unload(); } ``` --- ### 四、跨平台关键差异 | 平台 | 动态库扩展名 | 符号导出方式 | 依赖检查工具 | |-----------|--------------|-------------------------------|--------------------| | Windows | .dll | `__declspec(dllexport)` | Dependency Walker | | Linux | .so | `__attribute__((visibility("default")))` | ldd | | macOS | .dylib | 同Linux | otool -L | --- ### 五、常见问题解决方案 1. **"Cannot open shared object file"** - 将.so文件放入`/usr/lib`或设置`LD_LIBRARY_PATH` ```bash export LD_LIBRARY_PATH=/path/to/libs:$LD_LIBRARY_PATH ``` 2. **"Entry point not found"** - 使用`nm -gC libname.so`检查导出符号 - 确保使用相同的编译器(MSVC/MinGW不可混用) 3. **Qt版本不匹配** - 检查动态库构建时使用的Qt版本: ```bash strings libname.so | grep "Qt_" ``` --- ### 六、最佳实践建议 1. **版本控制**:在库文件名中包含版本号(如`MathLib_v1.2.3.dll`) 2. **ABI兼容**:保持以下一致性: - 编译器类型(MSVC/GCC) - 架构(32/64位) - Qt主要版本(Qt5/Qt6) 3. **错误处理**: ```cpp if(!QLibrary::isLibrary("MathLib.dll")) { qWarning() << "Invalid library format"; } ``` 通过合理配置动态库,可以实现模块化开发,典型应用场景包括: - 插件系统开发 - 第三方功能集成(如OpenCV图像处理) - 多团队协作开发时的代码隔离
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值