C语言内嵌Python import时提示undefined symbol错误及解决

发布时间 2023-07-19 20:08:39作者: DoubleLi
项目切gcc 4.6版本时,C语言内嵌了python,运行bin文件import时出现importError错误,提示python-2.7.11/lib/python2.7/lib-dynload/_collections.so: undefined symbol: _Py_ZeroStruct.
 
基本代码如下:
 
#include <Python.h>
#include <stdio.h>
#include <stdlib.h>
 
int main()
{
Py_Initialize();
PyRun_SimpleString("from time import time print 'Today is', ctime(time())/n");
Py_Finalize();
 
return 0;
}
编译选项:gcc -w -g -Wall -Werror
代码运行后出现importError,但在python解释器下执行没有问题,潜入C代码中就会出错。
 
原因在python的帮助手册5.6节Linking Requipments里有说明,不同的系统python的配置是不同的,可使用以下Python命令获取额外的编译选项。
 
>>> import distutils.sysconfig
>>> distutils.sysconfig.get_config_var('LINKFORSHARED')
'-Xlinker -export-dynamic'
编译选项加上“-Xlinker -export-dynamic”后,完美解决import问题。
 
这一选项是让gcc将"-export-dynamic"选项送入链接程序,输出符号给动态库使用。
即输出PyInt_FromLong给timemodule.so使用。
如果没有输出PyInt_FromLong,就会报
ImportError: /.../timemodule.so: undefined symbol: PyInt_FromLong
 
libPython库中虽然有PyInt_FromLong这个符号,可是链接程序查到该符号没有用到,所以缺省是不链入执行程序的。
而Python import动态调用了timemodule.so,就会用到PyInt_FromLong.
所以应该告知链接程序,不要丢弃符号。