作者asd24693120 (曙光)
看板C_and_CPP
标题[问题] linux呼叫so函式,执行出现undefined s..
时间Tue Feb 16 01:04:40 2021
开发平台(Platform): (Ex: Win10, Linux, ...)
Ubuntu 18.04LTS(在树莓派pi4)
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
g++
额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
Boost;UHD
问题(Question):
各位前辈好,目前遇到了一个问题,在建置so library档时,呼叫内部函式出现了undefi
ned symbol,目前完全不知道解决的方向,希望各位前辈能够指导
喂入的资料(Input):
sync_to_gps8.cpp
sync_to_gps8.i
sync_to_gps8.h
makefile
123.py
https://glot.io/snippets/fvwlmsu43t
预期的正确结果(Expected Output):
错误结果(Wrong Output):
https://i.imgur.com/ry81o7C.jpg
程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档)
https://glot.io/snippets/fvwlmsu43t
这是123.py的程式码
https://glot.io/snippets/fvwz2xprsu
补充说明(Supplement):
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 36.225.58.19 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1613408683.A.529.html
1F:推 art1: 你的 Python123 档案呢?02/16 02:16
2F:→ art1: 123.py 才对02/16 02:17
A大您好,我忘记放了,真的不好意思
https://glot.io/snippets/fvwz2xprsu
我有另外执行123.py,就会出现图片这样的结果
3F:→ ketrobo: 这个exception讯息很明确,就是swig载入这只程式时,找不02/16 04:17
4F:→ ketrobo: 到原本讲好要给他用的boost:: program_options:: value02/16 04:17
5F:→ ketrobo: _semantic_codecvt_helper,同时,发生这个问题的时间点是02/16 04:17
6F:→ ketrobo: 在执行程式的时候,这意味着程式码都已经编译完成,没有语02/16 04:17
7F:→ ketrobo: 法上的错误02/16 04:17
※ 编辑: asd24693120 (223.137.6.236 台湾), 02/16/2021 09:13:09
K大您好,但是我不是很懂已经有include进去也能用cpp跑,为什麽转成so就会找不到这
呢?想请问这样的问题该如何解呢?
※ 编辑: asd24693120 (118.169.185.235 台湾), 02/17/2021 13:49:30
8F:→ smartclever: 应该是没-lboost_program_options吧02/17 18:43
那想请问该如何解决呢
9F:→ ketrobo: 找个工具检查shared library相依关系02/18 08:29
请问k大是这个吗?
https://i.imgur.com/rVjD9Fr.jpg
10F:→ descent: 你在 .h 上加上 extern "C" 试试02/18 17:54
11F:→ zo6596001: c++编译的so档function name是乱码02/18 18:33
12F:→ zo6596001: python 跟c语言在link的时候找到是明码。02/18 18:34
13F:→ zo6596001: 加上extern c就可以了。02/18 18:35
我在.h档加上extern c後,好像还是一样
https://i.imgur.com/y6SX9oX.jpg
14F:→ zo6596001: 你可以尝试把c++跟C语言编译出来的so档dump出来,检查f02/18 18:41
15F:→ zo6596001: unction name是否为乱码。02/18 18:41
16F:→ Lipraxde: 乱码…恩…02/18 19:48
17F:→ ketrobo: 那个看起来乱码的其实是叫mangling,这个错误跟mangling02/18 21:25
18F:→ ketrobo: 没关系02/18 21:25
※ 编辑: asd24693120 (118.169.185.235 台湾), 02/19/2021 11:24:05
※ 编辑: asd24693120 (118.169.185.235 台湾), 02/19/2021 11:30:33
谢谢k大的解释,想请问k大目前这样该怎麽处理
※ 编辑: asd24693120 (118.169.185.235 台湾), 02/19/2021 11:31:26
※ 编辑: asd24693120 (118.169.185.235 台湾), 02/19/2021 11:35:10
19F:→ ketrobo: 因为可能带入错误的情境很多,主要是查你用的compiler/l02/19 13:14
20F:→ ketrobo: ibrary版本和编译时的参数,可能的就是下了std=c++14这些 02/19 13:14
21F:→ ketrobo: ,以及有没有连结到正确的library02/19 13:14
22F:→ zo6596001: 要不要尝试用ctypes?? 02/19 16:55
23F:→ zo6596001: 我自己用python call c library都会用ctypes,可以省02/19 16:58
24F:→ zo6596001: 掉很多麻烦。02/19 16:58
因为之前有参考过ctypes的用法,也有自己尝试过,但因为失败,所以就有点放弃,不知
道z大是否能指导?
25F:→ ketrobo: 如果只是想测看看能不能动,把program option 带入的参数 02/19 18:10
26F:→ ketrobo: 直接刻在程式里,把program option 相关的程式码移除掉, 02/19 18:10
27F:→ ketrobo: 应该有机会跑完02/19 18:10
回k大,因为这个c++这个程式码是我学长给我的,因此我也不知道是否哪些地方可以忽略
,想请问照您这样的方法,是否会影响到原本的结果?
※ 编辑: asd24693120 (111.250.156.31 台湾), 02/20/2021 16:41:02
28F:→ ketrobo: program option 只是读取使用者输入的参数 02/20 18:37
好的,我再试试,谢谢k大
29F:推 hellophoenix: 以前碰过compiler判断没使用到的function所以没l 02/20 23:47
30F:→ hellophoenix: ink,但是实际跑是会跑到,然後就会出这种runtim 02/20 23:47
31F:→ hellophoenix: e 才找不到symbol 的问题,给你参考。02/20 23:47
那想请问h大,这样要怎麽解决呢?因为目前就是compile没过
※ 编辑: asd24693120 (42.77.4.236 台湾), 02/25/2021 07:30:20
32F:推 hellophoenix: k大的在makefile 补上-l试过了吗 02/26 19:46
33F:→ hellophoenix: 错了 是s大 02/26 19:46