Python中文
首页
教程
问答
标签
搜索
登录
注册
Cython/Python/C++继承:将派生类作为参数传递给期望基类的函数
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<P>我使用Cython来包装一组C++类,允许Python接口。示例代码如下:</p> <p>基类.h:</p> <pre><code>#ifndef __BaseClass__ #define __BaseClass__ #include <stdio.h> #include <stdlib.h> #include <string> using namespace std; class BaseClass { public: BaseClass(){}; virtual ~BaseClass(){}; virtual void SetName(string name){printf("in base set name\n");} virtual float Evaluate(float time){printf("in base Evaluate\n");return 0;} virtual bool DataExists(){printf("in base data exists\n");return false;} }; #endif /* defined(__BaseClass__) */ </code></pre> <p>DerivedClass.h:</p> ^{pr2}$ <p>下一节课:</p> <pre><code>#ifndef __NextDerivedClass__ #define __NextDerivedClass__ #include "DerivedClass.h" class NextDerivedClass:public DerivedClass { public: NextDerivedClass(){}; virtual ~NextDerivedClass(){}; virtual void SetObject(BaseClass *input){printf("in set object of next derived class\n");} }; #endif /* defined(__NextDerivedClass__) */ </code></pre> <p>在继承测试.pyx公司名称:</p> <pre><code>cdef extern from "BaseClass.h": cdef cppclass BaseClass: BaseClass() except + void SetName(string) float Evaluate(float) bool DataExists() cdef extern from "DerivedClass.h": cdef cppclass DerivedClass(BaseClass): DerivedClass() except + void MyFunction() float Evaluate(float) bool DataExists() void SetObject(BaseClass *) cdef extern from "NextDerivedClass.h": cdef cppclass NextDerivedClass(DerivedClass): NextDerivedClass() except + # *** The issue is right here *** void SetObject(BaseClass *) cdef class PyBaseClass: cdef BaseClass *thisptr def __cinit__(self): if type(self) is PyBaseClass: self.thisptr = new BaseClass() def __dealloc__(self): if type(self) is PyBaseClass: del self.thisptr cdef class PyDerivedClass(PyBaseClass): cdef DerivedClass *derivedptr def __cinit__(self): self.derivedptr = self.thisptr = new DerivedClass() def __dealloc__(self): del self.derivedptr # def Evaluate(self, time): # return self.derivedptr.Evaluate(time) def SetObject(self, PyBaseClass inputObject): self.derivedptr.SetObject(<BaseClass *>inputObject.thisptr) cdef class PyNextDerivedClass(PyDerivedClass): cdef NextDerivedClass *nextDerivedptr def __cinit__(self): self.nextDerivedptr = self.thisptr = new NextDerivedClass() def __dealloc__(self): del self.nextDerivedptr def SetObject(self, PyBaseClass input): self.nextDerivedptr.SetObject(<BaseClass *>input.thisptr) </code></pre> <p>我希望能够在Python中调用SetObject,如下所示:</p> <p>在主.py公司名称:</p> <pre><code>from inheritTest import PyBaseClass as base from inheritTest import PyDerivedClass as der from inheritTest import PyNextDerivedClass as nextDer #This works now! a = der() b = der() a.SetObject(b) #This doesn't work -- keeping the function declaration causes a overloaded error, not keeping it means the call below works, but it calls the inherited implementation (From derived class) c = nextDer() c.SetObject(b) </code></pre> <p>我原以为这是可行的,因为这些类是相互继承的,但它给了我以下错误:</p> <p><i><em>参数的类型不正确:应为PyBaseClass,而get为PyDerivedClass</em></i></p> <p>在函数定义中不指定类型会使它认为inputObject是纯Python对象(它没有基于C的属性,但它没有),在这种情况下,错误是:</p> <p><i>*无法将Python对象转换为基类*</i></p> <p>一种解决这一问题的方法就是使用不同名称的Python函数来期望不同类型的参数(例如:SetObjectWithBase、SetObjectWithDerived),然后在它们的实现中,只需调用相同的基于C的函数,并将类型转换为输入。我知道这是可行的,但我想尽量避免这样做。即使有一种方法可以捕捉函数中的类型错误,并在函数内部处理它,我认为这可能有效,但我不确定如何实现它。在</p> <p>希望这个问题有意义,如果你需要更多的信息请告诉我。在</p> <p><b>****编辑*****</b>:已对代码进行了编辑,以便基本继承可以工作。在对它进行了更多的研究之后,我意识到问题发生在多个继承级别上,例如,请参阅上面编辑的代码。基本上,为NextDerivedClass保留SetObject声明会导致一个“不明确的重载方法”错误,不保留它允许我调用对象上的函数,但它调用继承的实现(从deriveClass)。**在</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>编写的代码无法编译。我怀疑你的实数<code>PyDerivedClass</code>并不是真的从<code>PyBaseClass</code>派生出来的,就像它真的那样</p> <pre><code>(<DerivedClass*>self.thisptr).SetObject(inputObject.thisptr) </code></pre> <p>这也可以解释你得到的类型错误,这是一个我无法重现的错误。在</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
为什么在使用strptime时会出现未进行转换的数据错误?
1 回答
为什么在使用strptim时会出现这个datetime日期错误
2 回答
为什么在使用StyleFrame时索引列的标题不显示sf.至excel()?
6 回答
为什么在使用sum()函数时会发生“int”对象不可调用的错误?
7 回答
为什么在使用sympy.dsolve时会得到“'list'对象没有属性'func'”?
5 回答
为什么在使用tabla时会得到一个空的数据帧?
7 回答
为什么在使用tensorboard时需要add_graph()的第二个参数?
7 回答
为什么在使用TensorFlow Lite转换YOLOv4时,推断时间/大小没有改进?有什么可能的改进吗?
8 回答
为什么在使用Tensorflow加载训练批时会出现内存泄漏?
1 回答
为什么在使用tensorflow时会收到警告/错误(使用函数API,但未实现错误)
8 回答
为什么在使用tetpyclient发出POST请求时出现403错误?
4 回答
为什么在使用TextBlob时会出现HTTP错误?
4 回答
为什么在使用TFIDF时出现错误“IndexError:list index out of range”pyspark.ml.feature?
1 回答
为什么在使用timedelta格式化之后,我在python中的日期是错误的?
7 回答
为什么在使用timeit或exec函数时,函数中的变量不会在提供的全局命名空间中搜索?
9 回答
为什么在使用tkinter时不能使用复选框?
3 回答
为什么在使用todoistpythonapi时会返回这个奇怪的ID?
4 回答
为什么在使用TQM时,在调整图像大小时,处理时间会有很大的差异?
10 回答
为什么在使用Tweepy下载用户时间线时收到错误消息
2 回答
为什么在使用twitter帐户登录Django应用程序时重定向127.0.0.1:8000?
1 回答