【C++】libgcc_s.so.1 must be installed for pthread_cancel to work

9 篇文章 0 订阅
3 篇文章 0 订阅

问题

在 C++ 工程中,使用 dlopen() 函数打开一个动态库时,出现如下错误:

2021-07-15 16:07:39 | dlopen() failed, lib: /mnt/aidot/libs/load/libAIDotBusiness.so, error: /mnt/aidot/libs/load/libAIDotBusiness.so: undefined symbol: _ZN8Workflow7finallyENSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt8functionIFvvEERKS5_
libgcc_s.so.1 must be installed for pthread_cancel to work
Aborted (core dumped)

解决方法

尝试了网上的一些解决方法之后还是没能解决这个问题,最后费劲千辛万苦发现是 CMakeLists 的问题!!!具体问题是:target_link_libraries() 中链接的静态库的顺序不对导致的这个问题,重新调整了顺序即可。

题外话

记录下我在使用过程中遇到的很奇怪的问题:

我在编译出动态库后(此时动态库中存在 undefined symbol),再基于此动态库编译出的可执行文件可以正常执行,但是使用 dlopen 方式打开此动态库时出现了崩溃的问题,提示如下的错误:

2021-07-15 16:07:39 | dlopen() failed, lib: /mnt/aidot/libs/load/libAIDotBusiness.so, error: /mnt/aidot/libs/load/libAIDotBusiness.so: undefined symbol: _ZN8Workflow7finallyENSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEESt8functionIFvvEERKS5_
libgcc_s.so.1 must be installed for pthread_cancel to work
Aborted (core dumped)

错误信息中提示了 Workflow 中的一个 finally() 方法未定义,但是我确实在编译此动态库时链接了 Workflow 所属的库文件(静态库)。

在尝试了网上的一些解决方法仍未果之后,我百思不得其解,无奈下我还是从报错信息入手,最后尝试修改编译动态库时链接库的顺序之后编译出的动态库中就没有了 undefined symbol ,崩溃的问题也得以解决。但是很奇怪的是,我是使用 CMakeLists 编译的工程,编译动态库的命令如下:

add_library(test_shared SHARED ${SRCS})
target_link_libraries(
            test_shared
            -Wl,--start-group
						xxx
						xxx
            -Wl,--end-group
    )

即,我已经在链接库时添加了 -Wl,–start-group 和 -Wl,–end-group 来规避链接库顺序的问题,但是最终看起来还是链接库的顺序引起的程序崩溃的问题,我调整了顺序之后就不再有崩溃的问题。

所以我在解决此问题之后仍然有两个疑问:

  1. 为什么动态库中有 undefined symbol 时我仍可以运行基于此动态库编译出的可执行文件
  2. 为什么我添加了 -Wl,–start-group 和 -Wl,–end-group 选项之后编译出的动态库仍有 undefined symbol 的问题,即使我已经添加动态库所需链接的库文件

有知道的朋友还请不吝赐教,感谢~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值