加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 如何防止全局覆盖的“新”运算符从外部库链接

发布时间:2020-12-14 19:57:54 所属栏目:百科 来源:网络整理
导读:在我们的iPhone XCode 3.2.1项目中,我们链接了2个外部静态C库,libBlue.a和libGreen.a. libBlue.a全局覆盖了“new”运算符,用于自己的内存管理.然而,当我们构建我们的项目时,libGreen.a最终会使用libBlue的new运算符,这会导致崩溃(可能是因为libBlue.a正在对
在我们的iPhone XCode 3.2.1项目中,我们链接了2个外部静态C库,libBlue.a和libGreen.a. libBlue.a全局覆盖了“new”运算符,用于自己的内存管理.然而,当我们构建我们的项目时,libGreen.a最终会使用libBlue的new运算符,这会导致崩溃(可能是因为libBlue.a正在对所分配的结构类型做出假设). libBlue.a和libGreen.a都是由第三方提供的,因此我们无法更改任何源代码或构建选项.

当我们从项目中删除libBlue.a时,libGreen.a没有任何问题.然而,没有任何数量的库的链接顺序混乱似乎解决了问题,也没有对各种链接标志进行任何实验.有没有办法让XCode告诉链接器“让libGreen使用new运算符使用标准的C new运算符而不是libBlue重新定义的运算符”?

解决方法

也许你可以调查使用 GNU objcopy,类似于objcopy –redefine-sym oldNew = newNew libBlue.a.我看到的最大问题是Apple的开发人员工具套件似乎不包括objcopy.您可以从 MacPorts(sudo port install binutils)安装objcopy,但该objcopy可能无法操作ARM对象文件.在MacPorts中有几个ARM binutils,我猜测arm-elf-binutils是你最好的选择.

除此之外,你可以反汇编libBlue.a,用sed脚本重命名它的新运算符,然后重新组装它.也许你甚至可以直接操作libBlue.a符号表.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读