只需在 Cython 中执行与在 C 中相同的操作,PyCObject_FromVoidPtrAndDesc
直接调用即可。这是您移植到 Cython 的链接中的示例:
###### example.pyx ######
from libc.stdlib cimport malloc, free
from cpython.cobject cimport PyCObject_FromVoidPtrAndDesc
cdef int _shift_function(int *output_coordinates, double* input_coordinates,
int output_rank, int input_rank, double *shift_data):
cdef double shift = shift_data[0]
cdef int ii
for ii in range(input_rank):
input_coordinates[ii] = output_coordinates[ii] - shift
return 1
cdef void _shift_destructor(void* cobject, void *shift_data):
free(shift_data)
def shift_function(double shift):
"""This is the function callable from python."""
cdef double* shift_data = <double*>malloc(sizeof(shift))
shift_data[0] = shift
return PyCObject_FromVoidPtrAndDesc(&_shift_function,
shift_data,
&_shift_destructor)
性能应该与纯 C 版本相同。
请注意,Cyhton 要求操作员&
获取函数地址。此外,Cython 缺少指针取消引用运算符*
,而是使用等效的索引 ( *ptr
-> ptr[0]
)。