我使用cffi将Python模块与C库接口。在
我在Linux上一切都很好,但是我对MacOSX(Yosemite-64位)却很不适应。下面是我写的一个最小示例,它显示了问题:
#ifndef FOO_H
#define FOO_H
#include <stddef.h>
#ifdef __cplusplus
extern "C" {
#endif
void* mymalloc(size_t);
#ifdef __cplusplus
}
#endif
#endif
run: foo.py libfoo.dylib
DYLD_LIBRARY_PATH=. LIBRARY_PATH=. python foo.py
libfoo.dylib: foo.cpp foo.h
g++ -dynamiclib -o $@ $<
import cffi
ffi = cffi.FFI()
ffi.cdef("""
void* malloc(size_t);
void* mymalloc(size_t);
""")
api = ffi.verify("", libraries=['foo'])
result = api.malloc(4)
print "malloc", result
result = api.mymalloc(4)
print "mymalloc", result
所以这里没有什么特别的:一个简单的mymalloc(size_t)
函数,它充当实际的malloc(size_t)
的包装器,并在返回之前显示生成的指针。在
但是,当执行foo.py
(使用make run
)时,我看到以下输出:
g++ -dynamiclib -o libfoo.dylib foo.cpp
DYLD_LIBRARY_PATH=. LIBRARY_PATH=. python foo.py
malloc <cdata 'void *' 0x7fdba0e01670>
0x7fdba0e00280
mymalloc <cdata 'void *' 0xffffffffa0e00280>
在mymalloc(size_t)
的情况下,cffi似乎以某种方式截断/修改了指针积分值:我得到了0xffffffffa0e00280
,而不是预期的{malloc(size_t)
具有完全相同的原型,但是cffi似乎正确地处理了它并返回了一个64位地址。在
我不知道我在这里做错了什么。有人知道吗?在
根据official answer的说法,我称
verify()
的方式是假的。在正确代码应为:
哪个指标产生了预期的结果!在
相关问题 更多 >
编程相关推荐