1

下面是我使用 ctypes 访问 dll 值的代码。

我的目的是存储结构字段地址。每当结构中的值发生更改时,我都可以访问地址并获取更改的值。

DUMMY_DLL_PATH = "dummyModel.dll"

class MyStruct(ctypes.Structure):  
    _fields_ = [("field_one", ctypes.c_int),  
                ("field_two", ctypes.c_int)]  

d_m = ctypes.cdll.LoadLibrary(DUMMY_DLL_PATH)  

d_i = MyStruct.in_dll(d_m,"dummy_In")  

in_field = ctypes.c_int(d_i.field_one)  

#storing the address  
b = ctypes.addressof(in_field)  
b_v = ctypes.cast(b,ctypes.POINTER(ctypes.c_int))  

k= b_v.contents   

print 'before',d_i.field_one,k.value  
#changing the value  
d_i.field_one = 10  

print 'After',d_i.field_one,k.value  

输出:

Before 0 0  
After 10 0  

通过指针,值不会改变。仍然为 0

4

1 回答 1

4

问题是in_field一个新c_int对象占用与原始结构不同的内存。您想要的是c_int.from_bufferdocs),它共享原始对象的内存。这是一个例子:

Windows DLL 源代码x.c编译为cl /LD x.c

struct MyStruct
{
    int one;
    int two;
};

__declspec(dllexport) struct MyStruct myStruct = {1,2};

Python脚本:

from ctypes import *

class MyStruct(Structure):
    _fields_ = [
        ("one", c_int),
        ("two", c_int)]
    def __repr__(self):
        return 'MyStruct({},{})'.format(self.one,self.two)

dll = CDLL('x')
struct = MyStruct.in_dll(dll,"myStruct")
alias1 = c_int.from_buffer(struct, MyStruct.one.offset)
alias2 = c_int.from_buffer(struct, MyStruct.two.offset)
print struct
print 'before',alias1,alias2
struct.one = 10
struct.two = 20
print 'after',alias1,alias2

输出:

MyStruct(1,2)
before c_long(1) c_long(2)
after c_long(10) c_long(20)
于 2012-08-29T12:26:10.990 回答