tos*_*bar 6 python ctypes python-3.x python-3.5
研究其他类似的错误,我认为我有一个非法操作的问题,例如写不该写的地址。我不确定如何解决此问题。有什么帮助吗?
我得到的确切错误:
in GetSoftwareVersion()
result = f(LCP_Version, FCP_Version)
OSError: exception: access violation writing 0x00000000
Run Code Online (Sandbox Code Playgroud)
我正在调用的函数
x = GetSoftWareVersion()
print(x)
Run Code Online (Sandbox Code Playgroud)
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
Run Code Online (Sandbox Code Playgroud)
编辑:添加相关的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;
}
Run Code Online (Sandbox Code Playgroud)
小智 5
OSError: exception: access violation writing 0x00000000
由于该语句,您得到了错误LCP_Version = ct.c_char_p(0)
。正如ctypes文档c_char_p
所建议的那样,您正在传递一个整数地址。
您要说的ctypes
是先char *
指向0
,然后尝试strcpy
通过指向它strcpy(LCP_Version, LCP_V.c_str());
。如果要使用ct.c_char_p(1)
,则会得到access violation writing 0x0000001
,if c_char_p(2)
,at 0x...2
等等。您的内存不太可能会或希望允许您写入该位置,因此会出现错误。
您可能想做的是使用create_string_buffer(N)
,其中N
包含的输出所需的数组大小为LCP_V = laserID->m_LCPSoftwareVersion;
。 create_string_buffer
,顾名思义,它将为您提供一个可变的char缓冲区,该缓冲区被初始化为空字节(例如,p = create_string_buffer(3)
均值p
为3,带有content b'\x00\x00\x00
)。您可以猜测并检查或查看的来源,p_DiagIF->GetLaserID();
以追索的安全值N
,或者只是给自己一些大的(用于版本号),例如,LCP_Version = ct.c_char_p(50)
然后从中挑选一些理智的东西。
归档时间: |
|
查看次数: |
11077 次 |
最近记录: |