免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2511 | 回复: 3
打印 上一主题 下一主题

[C] 【求助】主程序加载不同的动态库,但动态库中有同名的全局变量,会不会冲突? [复制链接]

论坛徽章:
3
巳蛇
日期:2014-04-24 17:25:352015年辞旧岁徽章
日期:2015-03-03 16:54:15NBA常规赛纪念章
日期:2015-05-04 22:32:03
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-10-26 12:43 |只看该作者 |倒序浏览
一、我的主程序main中需要加载动态库liba.so,libb.so,因为两个库中大多数代码是一样的,据有同名的全局变量,运行时会不会冲突?

二、写一个共享库libc.so,里面有全局变量G_A,编译时加-fpic选项。主程序MAIN依赖于libc.so和libm.so,库文件libm.so也依赖于libc.so, 运行时会不会加载两次libc.so?


《程序员的自我修养》看起来还得一些时间,哪位大侠能先告诉我答案??谢谢!

论坛徽章:
3
巳蛇
日期:2014-04-24 17:25:352015年辞旧岁徽章
日期:2015-03-03 16:54:15NBA常规赛纪念章
日期:2015-05-04 22:32:03
2 [报告]
发表于 2015-10-26 14:48 |只看该作者
第一个问题:我在ubuntu 64位下测试第一个问题,两个库编译时加-fPIC后,主程序运行中加载两个库,此时进程的maps文件中同名的全局变量拥有不同的地址,运算结果也相对独立。至于不加-fPIC时,由于编译会出问题所以暂时没有结论。
第二个问题:《程序员的自我修养》198页给出了答案,“所有指向这个变量的指令都指向位于可执行文件中的那个副本。ELF共享库在编译时,默认把模块内部的全局变量当作定义在其他模块中的全局变量,通过GOT实现变量的访问”。通过对主程序maps文件的分析,liba.so只加载一次。

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
3 [报告]
发表于 2015-10-27 15:25 |只看该作者
紫柳 发表于 2015-10-26 14:48
...
所有指向这个变量的指令都指向位于可执行文件中的那个副本。ELF共享库在编译时,默认把模块内部的全局变量当作定义在其他模块中的全局变量,通过GOT实现变量的访问”。通过对主程序maps文件的分析,liba.so只加载一次。


谢谢分享!
按照这么说的话,如果两个so都初始化了这个全局变量,那么可执行文件第一次访问该全局变量得到的值 取决于 两个so的加载顺序?

论坛徽章:
3
处女座
日期:2015-03-18 14:35:45羊年新春福章
日期:2015-03-18 14:48:23午马
日期:2015-03-18 14:51:09
4 [报告]
发表于 2015-11-19 10:38 |只看该作者
1. 不会冲突,  只是根据你动态库链接时候的排列顺序,先加载排列前面的一个,然后填充got中a的地址,a的原先地址是指向动态库符号解析的一个函数,所以这个和链接动态库排列顺序有关。
2. 不会
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP