c++ 链接器错误"针对'.rodata.str1.1'的重新定位R_X86_64_32"链接 CXX 共享库 libsrt.so
c++ Linker error 'relocation R_X86_64_32 against `.rodata.str1.1' Linking CXX shared library libsrt.so
每次运行make时我都会收到此错误。如果我从另一个目录复制 libsrt.so,那么它就会被编译。有人知道吗?
Linking CXX shared library libsrt.so
/usr/bin/ld: /usr/local/ssl/lib/libcrypto.a(aes_misc.o): relocation R_X86_64_32 against `.rodata.str1.1' can not be used when making a shared object; recompile with -fPIC
/usr/local/ssl/lib/libcrypto.a: error adding symbols: Bad value
collect2: error: ld returned 1 exit status
CMakeFiles/srt.dir/build.make:763: recipe for target 'libsrt.so.1.2.0' failed
错误消息告诉您的是,libsrt.so
的链接失败,因为您尝试将libsrt.so
与libcrypto.a
链接,但libcrypto.a
不符合-fPIC
。
-fPIC
是一个编译器标志,它将代码生成更改为共享对象所需的生产位置独立代码 (PIC(,因为链接器不知道共享对象的加载位置。
要解决此问题,您可以:
- 如果您自己遵守,请重新
libcrypto.a
与-fPIC
- 如果您收到了编译的二进制文件,请使用 libcrypto
libcrypto.so
的共享对象
在您的情况下,libCrypto 使用libcrypto.so
成为 OpenSSL 的一部分要好得多
您需要构建libcrypto
的共享版本 -libcrypto.so
。并针对此链接(当存在.so
时,链接器会自动执行此操作(。
相关文章:
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 从链接列表c++中删除一个项目
- 有根的二进制搜索树.保留与其父级的链接
- 读取文件的最后一行并输入到链接列表时出错
- 静态数据成员的问题-修复链接错误会导致编译器错误
- node-gyp 在 macOS 上未正确链接库
- 基于boost的程序的静态链接——zlib问题
- 无法链接 CMake 中的本地库
- 内联函数中具有内部链接的全局变量
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 使用gcc从静态链接的文件中查找可选符号
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 将--whole archive链接器选项与CMake和具有其他库依赖项的库一起使用
- 下面是我为检测链接列表中的循环而制作的代码
- 链接器问题:目标不是 x86
- Solaris 5.10 x86 CC链接器错误:ld:致命:找不到库-lcryptoki:
- 链接错误:QtCore.framework/Versions/4/QtCore for Architecture x86
- 用于调试X86构建的Visual Studio链接器错误
- 将c++项目类型从x86更改为x64后的链接器错误