python.net import clr抛出无效指针错误

时间:2015-07-31 15:34:13

标签: python linux mono ubuntu-14.04 python.net

当我尝试在我的python代码中导入clr时,我收到以下错误:

*** Error in `python': free(): invalid pointer: 0xb0f1a120 ***
Stacktrace:

  at <unknown> <0xffffffff>
  at (wrapper managed-to-native) Python.Runtime.Runtime.Py_Initialize () <0xffffffff>
  at Python.Runtime.Runtime.Initialize () <0x00023>
  at Python.Runtime.PythonEngine.Initialize () <0x00047>
  at Python.Runtime.PythonEngine.InitExt () <0x0000b>
  at (wrapper runtime-invoke) object.runtime_invoke_void (object,intptr,intptr,intptr) <0xffffffff>

Native stacktrace:

    /usr/lib/libmonoboehm-2.0.so.1(+0xcb5f4) [0xb1b5e5f4]
    [0xb7745d14]
    [0xb7745d1e]
    /lib/i386-linux-gnu/libc.so.6(gsignal+0x47) [0xb7592607]
    /lib/i386-linux-gnu/libc.so.6(abort+0x143) [0xb7595a33]
    /lib/i386-linux-gnu/libc.so.6(+0x68e53) [0xb75cce53]
    /lib/i386-linux-gnu/libc.so.6(+0x7333a) [0xb75d733a]
    /lib/i386-linux-gnu/libc.so.6(+0x73fad) [0xb75d7fad]
    /usr/lib/i386-linux-gnu/libpython2.7.so(PyString_InternInPlace+0x97) [0xb0b3a157]
    /usr/lib/i386-linux-gnu/libpython2.7.so(PyString_InternFromString+0x2f) [0xb0ad78ef]
    /usr/lib/i386-linux-gnu/libpython2.7.so(PyType_Ready+0xb50) [0xb0b356e0]
    /usr/lib/i386-linux-gnu/libpython2.7.so(_Py_ReadyTypes+0xcd) [0xb0b3d47d]
    /usr/lib/i386-linux-gnu/libpython2.7.so(Py_InitializeEx+0x6d) [0xb0b5d5dd]
    /usr/lib/i386-linux-gnu/libpython2.7.so(Py_Initialize+0x1b) [0xb0b5df7b]
    [0xb481553c]
    [0xb4814f2c]
    [0xb480af98]
    [0xb480ae84]
    [0xb480af0d]
    /usr/lib/libmonoboehm-2.0.so.1(+0x29723) [0xb1abc723]

Debug info from gdb:

Could not attach to process.  If your uid matches the uid of the target
process, check the setting of /proc/sys/kernel/yama/ptrace_scope, or try
again as the root user.  For more details, see /etc/sysctl.d/10-ptrace.conf
ptrace: Operation not permitted.
No threads.

=================================================================
Got a SIGABRT while executing native code. This usually indicates
a fatal error in the mono runtime or one of the native libraries 
used by your application.
=================================================================

我发现了对类似问题的引用(https://mail.python.org/pipermail/pythondotnet/2014-October/001598.html),但我无法弄清楚如何使用npython二进制文件,我不希望在启用共享库的情况下重建python。

任何提示或帮助将不胜感激。

2 个答案:

答案 0 :(得分:1)

经过一些痛苦的试验后,我在代码中成功使用import clr

首先,我需要以某种方式使用正确的二进制文件,为了实现我使用pythonnet / pythonnet包的git的最新开发源。

您可以尝试:$ sudo pip install --pre pythonnet下载并安装最新的开发源代码。但请记住,有一些必要条件,所以我附上了travis构建细节

system_info
Build language: python
Operating System:   Ubuntu 12.04 LTS
$ python --version
Python 2.7.9
$ pip --version
pip 6.0.7 from /home/travis/virtualenv/python2.7.9/lib/python2.7/site-packages (python 2.7)
$ sudo apt-get install software-properties-common
$ sudo add-apt-repository -y "deb http://archive.ubuntu.com/ubuntu/ trusty main universe"
$ sudo apt-get -qq install mono-devel mono-gmcs mono-xbuild nunit-console
$ sudo mozroots --import --machine --sync
$ yes | sudo certmgr -ssl -m https://go.microsoft.com
$ yes | sudo certmgr -ssl -m https://nugetgallery.blob.core.windows.net
$ yes | sudo certmgr -ssl -m https://nuget.org
$ pip install six

现在通常用pip安装pythonnet应该成功执行,你可以尝试在你的python代码中调用import clr。在我个人的情况下,即使在这种情况下,它也是失败的,尽管安装没有错误。原因是虽然我的python是在没有--enable-shared,运行

的情况下编译的
$ python -c 'import sys; from distutils.sysconfig import get_config_var; print(get_config_var("Py_ENABLE_SHARED"))'

返回1,但它应该返回0.

所以我从git https://github.com/pythonnet/pythonnet

下载了最新的dev-source

将它放入正确的文件夹后,我编辑了setup.py设置变量  在执行

之后检查共享库为0
$ sudo python setup.py install

脚本安装成功且没有错误,我可以在我的python脚本中使用import clr。为确保一切正常运行,您可以运行:

$ python src/tests/runtests.py

答案 1 :(得分:1)

以后参考,Pythonnet issue #119

解决了这个问题

添加...

defines.append("PYTHON_WITHOUT_ENABLE_SHARED")

...到setup.py,然后使用python setup.py install [options]进行安装,效果与answer相同。

相关问题