研究其他类似的错误,我认为我有一个非法操作的问题,比如写一个我不应该写的地址。我不知道如何解决这个问题。有什么帮助吗?
我得到的确切错误:
in GetSoftwareVersion()
result = f(LCP_Version, FCP_Version)
OSError: exception: access violation writing 0x00000000
我打电话的功能
x = GetSoftWareVersion()
print(x)
GetSoftwareVersion()内容
def GetSoftwareVersion():
f = shim.GetSoftwareVersion
LCP_Version = ct.c_char_p(0)
FCP_Version = ct.c_char_p(0)
result = f(LCP_Version, FCP_Version)
if result:
print(find_shim_error(result))
return LCP_Version.contents.value, FCP_Version.contents.value
编辑:添加相关的C ++代码
PCSHIMDLL_API error_status_type GetSoftwareVersion(
char* LCP_Version,
char* FCP_Version
)
{
error_status_type return_status = SUCCESS;
string LCP_V("");
string FCP_V("");
LaserIDType_var laserID;
laserID = p_DiagIF->GetLaserID();
LCP_V = laserID->m_LCPSoftwareVersion;
FCP_V = laserID->m_FCPSoftwareVersion;
strcpy(LCP_Version, LCP_V.c_str());
strcpy(FCP_Version, FCP_V.c_str());
return return_status;
}
答案 0 :(得分:5)
由于声明OSError: exception: access violation writing 0x00000000
,您收到错误LCP_Version = ct.c_char_p(0)
。正如ctypes documentation for c_char_p
所建议的那样,你传递了一个整数地址。
您告诉ctypes
要做的是将char *
指向0
,然后通过strcpy
尝试strcpy(LCP_Version, LCP_V.c_str());
。如果您使用ct.c_char_p(1)
,则会获得access violation writing 0x0000001
,c_char_p(2)
,0x...2
,依此类推。您的内存不太可能或者想要允许您写入该位置,因此错误。
您可能想要做的是使用create_string_buffer(N)
,其中N
是包含LCP_V = laserID->m_LCPSoftwareVersion;
输出所需的数组大小。顾名思义,create_string_buffer
将为您提供一个可变的char缓冲区,该缓冲区初始化为空字节(例如p = create_string_buffer(3)
表示p
的大小为3,内容为b'\x00\x00\x00
)。您可以猜测并查看或查看p_DiagIF->GetLaserID();
的来源以追捕N
的安全值,或者只是给自己一些巨大的(对于版本号)LCP_Version = ct.c_char_p(50)
并挑选一些东西从那里理智。