c – 将存档(.a)链接到共享对象(.so)

c – 将存档(.a)链接到共享对象(.so),第1张

概述我正在将一些共享对象文件编译到archive.a中: $g++ -c -Iinclude/ -fPIC -O0 -o object1.o source1.cpp$g++ -c -Iinclude/ -fPIC -O0 -o object2.o source2.cpp$ar rvs archive.a object1.o object2.or - object1.or - object2.o 我正在将一些共享对象文件编译到archive.a中:
$g++ -c -Iinclude/ -fPIC -O0 -o object1.o source1.cpp$g++ -c -Iinclude/ -fPIC -O0 -o object2.o source2.cpp$ar rvs archive.a object1.o object2.or - object1.or - object2.o

到现在为止还挺好.最终的archive.a具有一些KB的大小.带有nm的转储表示相应的对象文件包含在文件中.

现在我想将这些档案中的几个编译成一个共享对象文件.

g++ -g -O0 -Iinclude/ -I/usr/include/somelibrary -shared -o liblibrary.so archive1.a archive2.a

结果是我生成的库文件几乎是空的:

$nm -D liblibrary.so                 w _Jv_RegisterClasses0000000000201010 A __bss_start                 w __cxa_finalize                 w __gmon_start__0000000000201010 A _edata0000000000201020 A _end0000000000000578 T _fini0000000000000430 T _init

任何想法我在做错什么?

编辑:

当我尝试切换-Wl,– 整个档案,以下情况发生:

/usr/lib/x86_64-linux-gnu/libc_nonshared.a(elf-init.oS): In function `__libc_csu_init':(.text+0xd): undefined reference to `__init_array_end'/usr/bin/ld: /usr/lib/x86_64-linux-gnu/libc_nonshared.a(elf-init.oS): relocation R_X86_64_PC32 against undefined hIDden symbol `__init_array_end' can not be used when making a shared object/usr/bin/ld: final link Failed: Bad valuecollect2: ld returned 1 exit statusmake: *** [libKeynect.so] Error 1
解决方法 链接器将丢弃未使用的.a文件中的符号/对象文件.

使用-Wl,– 用于链接的整个归档,以包括整个.a文件编辑后,您还需要在指定库之后添加-Wl,– no-whole-archive,所以整个事情将是-Wl,– 整个归档archive1.a archive2.a -Wl,– -no-整个归档

总结

以上是内存溢出为你收集整理的c – 将存档(.a)链接到共享对象(.so)全部内容,希望文章能够帮你解决c – 将存档(.a)链接到共享对象(.so)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1234583.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存