繁体   English   中英

导入 C++ 在 Python 中共享 object 时出现分段错误

[英]Segmentation fault when importing a C++ shared object in Python

我有以下共享 object:

MyLib.cpp

#include <iostream>

class MyClass
{
 public:
 MyClass(){}

 void function()
 {
  std::cout << "hello" << std::endl;
  //var = 10;
 }

 private:

 int var;

};



extern "C" {
 MyClass* create()
 {
  return new MyClass();
 }


 void func(MyClass* myclass)
 {
  myclass->function();
 }

}

我编译的是: g++ -fPIC -shared -o MyLib.so MyLib.cpp

然后我将它与以下 Python 脚本一起使用:

脚本.py

import ctypes

lib = ctypes.cdll.LoadLibrary("./MyLib.so")

MyClass = lib.create()
lib.func(MyClass)

像这样,它工作得很好,但如果我取消注释行//var = 10; , Python 产生分段错误(Python 3.8)。 每次 object MyClass对其局部变量之一进行更改时都会发生这种情况(构造函数内部除外,它在其中工作)。 看起来变量var的地址是错误的,并且在访问它时出现了分段错误。 我尝试对function使用关键字“virtual”而不做任何更改,我尝试使用 dlfcn 在另一个 C++ 程序中导入共享的 object,效果很好。 知道有什么问题吗?

指针不一样:

extern "C" {
    MyClass* create()
    {
        MyClass* myclass = new MyClass();
        std::cerr << "Returning: " << myclass << "\n";
        return myclass;
    }


    void func(MyClass* myclass)
    {
        std::cerr << "Calling:   " << myclass << "\n";
        myclass->function();
    }

}

运行我得到:

Returning: 0x7faab9c06580
Calling:   0xffffffffb9c06580

看起来某处存在符号扩展问题。

您需要告诉 python 传递的对象的类型,否则它认为它们是int并且会发生令人讨厌的事情:

import ctypes

lib = ctypes.cdll.LoadLibrary("./MyLib.so")
lib.create.restype = ctypes.c_void_p;
lib.func.argtypes = [ ctypes.c_void_p ];


MyClass = lib.create();
lib.func(MyClass)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM