0

我正在做一个 cffi 测试演示,当我尝试运行 python 测试器文件时,它返回以下错误: TypeError: initializer for ctype 'Car *' 似乎确实是 'Car *',但类型不同(检查您是否没有混淆不同的 ffi 实例)

car.h 文件定义了 C 结构 Car,如下所示:

/*Class definition for car*/
     typedef struct {
     char make[32];
     char model[32];
     char year[32];
     char color[32];
     } Car;

这是我试图用来测试 C 代码的使用 cffi 的 python 文件。

import unittest
import cffi
import importlib

ffi=cffi.FFI()
def load(filename):
    #load source code
    source = open('../src/' + filename + '.c').read()
    includes = open('../include/' + filename + '.h').read()

    #pass source code to CFFI
    ffi.cdef(includes)
    ffi.set_source(filename + '_', source)
    ffi.compile()

    #import and return resulting module
    module = importlib.import_module(filename + '_')
    return module.lib

class carTest(unittest.TestCase):
    def test_setMake(self):
        module = load('car')

        myCar = ffi.new('Car *',
           ["Honda", "Civic", "1996", "Black"])
        make = ("char []", "Honda")

        self.assertEqual(module.setMake(myCar, make),
                car)

if __name__ == '__main__':
    unittest.main()

任何关于这个问题的建议都将非常受欢迎。我觉得我已经经历了一百次。

提前致谢

4

1 回答 1

0

这是因为您正在混合两个不相关的ffi实例。您可以在函数内部显式创建并使用它load()来制作 C 扩展模块;在这种用法中,我们建议调用它ffibuilder而不是ffi. 但是然后你导入编译的模块,你会得到一个不同的ffi实例module.ffi;那个来自 C 扩展模块。理想情况下,您不应再使用ffibuilderafter 编译。

我建议更改load()为同时返回module.ffiand module.lib(或者可能只是module),终止全局声明,并在函数内部ffi创建本地 a 。ffibuilder = cffi.FFI()load()

于 2017-08-19T08:21:53.900 回答