ctypes,python3.5,OSError:异常:访问冲突写入0x00000000

时间:2016-06-22 15:57:17

标签: python python-3.x ctypes python-3.5

研究其他类似的错误,我认为我有一个非法操作的问题,比如写一个我不应该写的地址。我不知道如何解决这个问题。有什么帮助吗?

我得到的确切错误:

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;
}

1 个答案:

答案 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 0x0000001c_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)并挑选一些东西从那里理智。