未定义的boost python符号:boost::python::detail::init_module

4
当我尝试导入使用boost python编译的扩展时,出现了未定义符号错误,这个符号应该包含在boost库中。
我正在使用Boost 1.46.1、Python 3.1.2和GCC 4.4.5。
我使用以下命令构建了boost:
$ ./bootstrap.sh --with-python-version=3.1
$ sudo ./bjam -j4 install

我随后编译了以下简单的Boost Python库:
#include <boost/python.hpp>

struct mystruct {
    int i;
};

BOOST_PYTHON_MODULE(test) {
    using namespace boost::python;
    class_<mystruct>("Mystruct")
        .def_readwrite("i", &mystruct::i)
        ;
}

使用以下命令:

$ g++ -shared question.cpp -I/usr/include/python3.1 -lboost_python3 -lpython3.1 -otest.so

没有错误地成功执行。

然后我尝试在Python中运行它,但似乎找不到Boost Python应该提供的init_module函数:

$ python3
Python 3.1.2 (release31-maint, Sep 17 2010, 20:34:23) 
[GCC 4.4.5] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import test
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ImportError: ./test.so: undefined symbol: _ZN5boost6python6detail11init_moduleEPKcPFvvE

ldd 报告如下:

$ ldd -r test.so
    linux-gate.so.1 =>  (0x00ab3000)
    libboost_python3.so.1.46.1 => /usr/local/lib/libboost_python3.so.1.46.1 (0x002fe000)
    libpython3.1.so.1.0 => /usr/lib/libpython3.1.so.1.0 (0x005dc000)
    libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x001f8000)
    libm.so.6 => /lib/libm.so.6 (0x00110000)
    libgcc_s.so.1 => /lib/libgcc_s.so.1 (0x00424000)
    libc.so.6 => /lib/libc.so.6 (0x00886000)
    libutil.so.1 => /lib/libutil.so.1 (0x00e13000)
    libpthread.so.0 => /lib/libpthread.so.0 (0x00136000)
    libdl.so.2 => /lib/libdl.so.2 (0x00349000)
    librt.so.1 => /lib/librt.so.1 (0x00150000)
    libssl.so.0.9.8 => /lib/libssl.so.0.9.8 (0x00553000)
    libcrypto.so.0.9.8 => /lib/libcrypto.so.0.9.8 (0x00ab4000)
    libffi.so.5 => /usr/lib/libffi.so.5 (0x00159000)
    libz.so.1 => /lib/libz.so.1 (0x00160000)
    libexpat.so.1 => /lib/libexpat.so.1 (0x00175000)
    /lib/ld-linux.so.2 (0x00495000)
undefined symbol: _ZN5boost6python6detail11init_moduleEPKcPFvvE (./test.so)

编辑:

nm 确认 /usr/local/lib/libboost_python3.so.1.46.1 确实包含 init_module,但错误仍然存在:

$ nm /usr/local/lib/libboost_python3.so.1.46.1 | c++filt | grep init_module
00031a00 T boost::python::detail::init_module(PyModuleDef&, void (*)())
1个回答

6
未定义符号是指在链接时无法找到其实际定义的符号。
boost::python::detail::init_module(char const*, void (*)())

不是

boost::python::detail::init_module(PyModuleDef&, void (*)())

我在http://www.boost.org/doc/libs/1_46_1/boost/python/module_init.hpp上看到,在Python 3中,方法签名已更改为后者。

在处理boost python头文件时,请确保正确设置PY_VERSION_HEX

在我的系统上,我看到这个值被定义在/usr/include/python3.1/patchlevel.h中(但我必须先安装Python 3.1的开发包)。


非常感谢。奇怪的是,Boost Python 1.45.0似乎可以在没有Python开发包的情况下工作。 - vsekhar
但看起来确实是链接器抱怨没有PyModuleDef&这个东西。@vsekhar,你只需安装python-dev就解决了这个问题吗? - murrayc

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接