SQLite3库链接与加载问题解决方案

orangepi@orangepizero2:~/embedded_Database/sqlite ls /usr/local/lib/ libsqlite3.a libsqlite3.so.0 libwiringPiDev.so libwiringPi.so pkgconfig python3.6 libsqlite3.so libsqlite3.so.3.50.4 libwiringPiDev.so.2.58 libwiringPi.so.2.58 python2.7 orangepi@orangepizero2:\~/embedded_Database/sqlite orangepi@orangepizero2:~/embedded_Database/sqlite orangepi@orangepizero2:\~/embedded_Database/sqlite gcc openSqlite.c -lsqlite3 orangepi@orangepizero2:~/embedded_Database/sqlite ./a.out ./a.out: error while loading shared libraries: libsqlite3.so: cannot open shared object file: No such file or directory orangepi@orangepizero2:\~/embedded_Database/sqlite

输出可以看到,libsqlite3.so 确实存在于 /usr/local/lib/,但运行时仍然找不到。这是因为 Linux 默认不会自动搜索 /usr/local/lib/ 下的共享库(.so 文件),除非该路径被添加到动态链接器的搜索路径中。

解决方法

cpp 复制代码
方法 1:临时添加 /usr/local/lib/ 到 LD_LIBRARY_PATH(仅当前终端有效)
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
./a.out
这样,程序运行时就会在 /usr/local/lib/ 下查找 libsqlite3.so。

方法 2:永久添加 /usr/local/lib/ 到系统库搜索路径
(推荐)方法 
2.1:更新 /etc/ld.so.conf
    检查 /etc/ld.so.conf 是否包含 /usr/local/lib/:
    cat /etc/ld.so.conf
    如果没有,可以手动添加:
    sudo sh -c "echo '/usr/local/lib' >> /etc/ld.so.conf"
    更新动态链接器的缓存:
    sudo ldconfig
    再次运行程序:
    ./a.out

方法 2.2:
    在 /etc/ld.so.conf.d/ 下创建新配置文件
    echo '/usr/local/lib' | sudo tee /etc/ld.so.conf.d/local_lib.conf
    sudo ldconfig
    ./a.out

方法 3:编译时指定运行时库路径(避免修改系统配置)
    gcc openSqlite.c -lsqlite3 -Wl,-rpath=/usr/local/lib -o a.out
    -Wl,-rpath=/usr/local/lib 告诉链接器在运行时优先从 /usr/local/lib 加载共享库。
    这样即使 LD_LIBRARY_PATH 没有设置,程序也能找到 libsqlite3.so。

方法 4:静态链接 SQLite3(完全避免动态库依赖)
    gcc openSqlite.c /usr/local/lib/libsqlite3.a -o a.out
    这样编译后,a.out 会直接包含 SQLite3 的代码,不再依赖 libsqlite3.so。

为什么会出现这个问题?
    Linux 默认只搜索 /lib 和 /usr/lib,而 /usr/local/lib 通常需要手动配置。
    你的 libsqlite3.so 在 /usr/local/lib/,但动态链接器(ld.so)默认不会搜索这个路径。
    通过 LD_LIBRARY_PATH、ldconfig 或 -rpath 可以解决这个问题。

验证是否解决
    运行:
    ldd ./a.out
    如果输出显示 libsqlite3.so 已经正确找到(而不是 not found),说明问题已解决。

总结
    ✅ 推荐方法:

    临时测试:export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH

    永久解决:sudo ldconfig(确保 /usr/local/lib 在 ld.so.conf 里)

    编译时指定路径:gcc ... -Wl,-rpath=/usr/local/lib

这样应该就能让 ./a.out 正常运行了! 🚀
相关推荐
闪电悠米2 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
DIY源码阁2 小时前
JavaSwing航班订票管理系统 - MySQL版
数据库·mysql
浪客灿心4 小时前
项目篇:模块设计与实现
数据库·c++
流星白龙5 小时前
【MySQL高阶】26.事务(1)
数据库·mysql
三十..6 小时前
Redis 核心原理与高可用架构实践
运维·数据库·redis
这个DBA有点耶6 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构
努力努力再努力wz6 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
JdSnE27zv7 小时前
Qt 操作SQLite数据库
数据库·qt·sqlite
tedcloud1237 小时前
HyperFrames部署教程:用HTML生成MP4视频
前端·数据库·人工智能·html·音视频
布朗克1687 小时前
25 IO流高级操作——序列化、NIO与Files工具类
java·数据库·io·nio