python - Python/Ctypes - 访问指针(到数组)时出现分段错误
问题描述
这很相似,只是我没有得到单个值,而是 [0] 或 .contents 上的段错误
如何从 Python 访问“数组”中的元素?
在 CI 中有类似的东西
#pragma pack(push, 1)
struct Data {
int i;
int *array;
};
#pragma pack(pop)
typedef struct {
bool (* const get) (struct Data*, const char *source);
void (* const print) (struct Data*);
} DataFn;
extern DataFn const DATAFUNC;
在 Python 中,我有类似的东西
class Data(ctypes.Structure):
_fields_ = [
("i", ctypes.c_int),
("array", ctypes.POINTER(ctypes.c_int))
]
class DATA_FN(ctypes.Structure):
_fields_ = [
("get" , ctypes.CFUNCTYPE(
ctypes.c_bool,
ctypes.POINTER(Data),
ctypes.c_char_p)),
("print" , ctypes.CFUNCTYPE(None,
ctypes.POINTER(Data)))
]
从python我可以做类似..
with open("xx0c.exx", "rb") as f:
fdata = f.read()
dfn.get(ctypes.byref(data),f fdata)
dfn.print(ctypes.byref(data))
print(data)
print(data.i) #7, correct
#print(data.array.contents) #segfault
#print(data.array) #segfault
ptr = ctypes.pointer(data)
print(ptr.contents.array[0]) #segfault
从 python 调用的 C 函数将打印 .. 这是正确的
我 = 7
数组 = 0x6ffff360034
数组 0 = 20
数组 1 = 27a40
数组 2 = 127e20
数组 3 = 128ae0
数组 4 = 47e850
数组 5 = 57ec30
数组 6 = 580230
我可以看到 python 中的数组不在 C 中的数组附近。
按要求提供示例 C 代码。这些是静态的,但可以通过 DATAFUNC 访问它们。使用这些的 C 程序很好。
static bool getdata(struct Data *d, const char *filedata) {
bool good = false;
if (d != NULL && filedata != NULL) {
d -> i = (int32_t)filedata[0];
d -> array = (uint32_t*)(filedata + sizeof(int32_t));
if ( d->i > 0 ) {
good = true;
}
}
return good;
}
static void printdata(struct Data *d) {
if (d == NULL) {
return;
}
printf("i = %i\n", d -> i);
printf("array = %p\n", d -> array);
unsigned int i;
for (i = 0; i < d -> i; i++) {
printf("array %i = %x\n", i, d -> array[i]);
}
}
解决方案
我已经通过将包添加到 python 结构解决了这个问题,如下所示。
class Data(ctypes.Structure):
_pack_ = 1
_fields_ = [
("i", ctypes.c_int),
("array", ctypes.POINTER(ctypes.c_int))
]
这修复了所有问题,并在添加循环以遍历数组后给出 .. 的输出。
number of offsets = 7
offsets = 0x6ffff360034
offset 0 = 20
offset 1 = 27a40
offset 2 = 127e20
offset 3 = 128ae0
offset 4 = 47e850
offset 5 = 57ec30
offset 6 = 580230
<__main__.Data object at 0x6ffffd5f400>
7
<__main__.LP_c_int object at 0x6ffffd5f488>
0x20
0x27a40
0x127e20
0x128ae0
0x47e850
0x57ec30
0x580230
推荐阅读
- gcc - 尝试实现观察者模式并得到分段错误(请帮助)c ++
- php - php中的日期问题
- swift - Swift 解码和编码自定义类型
- c# - 无法通过 MediatR 使用范围服务
- wordpress - WordPress Polylang 不显示语言图标
- python - 在 Python 中循环访问 API GET 请求的 API 值数组
- objective-c - 从窗口菜单中删除与选项卡相关的功能?
- javascript - FireBase 调度功能不保存到实时数据库
- python - Pyglet 图像绘制问题
- azure - Azure 发布管道不断将“.scm”添加到 appservice 的 URL