__gnu_cxx::__concurrence_broadcast_error错误解决方法

在交叉编译arm平台时遇到__gnu_cxx::__concurrence_broadcast_error错误,通过在g++编译选项中添加-Wl,--whole-archive -lpthread -Wl,--no-whole-archive -lc解决。该问题可能源于静态编译和-lpthread的组合,--whole-archive确保pthread库所有函数被包含,而--no-whole-archive避免libc全量引入。参考链接提供详细解决方案。" 104556474,8827322,改进型最小损耗能量密度算法在异构多核平台的能源优化,"['嵌入式系统', '能源管理', '多核处理器', '性能优化', '硬件优化']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  最近修改代码在主机编译运行正常,但是交叉编译在arm平台上运行出现下面错误:

terminate called after throwing an instance of '__gnu_cxx::__concurrence_broadcast_error'
what():  __gnu_cxx::__concurrence_broadcast_error

在google上搜了一通,找到了解决的方案,在g++的选项中加入:

-Wl,--whole-archive -lpthread -Wl,--no-whole-archive -lc

查看g++的编译选项可以知道-WL是指定链接器的选项,因此可以通过ld --help查看可以找到--whole-archive的含义

我的理解是这样的,因为我的编译是静态编译,加了-static选项,但是在最后链接了-lpthread,需要将pthread库中的函数和变量都链接进入可执行文件中,就需要--whole-archive,官方解释这个选项的含义是将其后出现的静态库的变量和函数输出到动态库中,但是我感觉这个对上面的问题没有合理的解释,我的理解应该是这个--whole-archive选项将其后的库中的变量和函数输出到可执行文件中,--no-whole-archive则相反。

上面修改的含义就是讲pthread库中的所有函数都输出到可执行文件中,而libc库不是所有函数都输出到可执行文件中。

这个可能只有pthread库会出现这个问题吧。

这样改之后的确是没有问题了,具体修改如下:

CXXFLAG = -Wl,--whole-archive -lpthread       -Wl,--no-whole-archive -lc

LDFLAG = -static

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值