0

在我的应用程序中,我打开了一个共享内存的句柄,我读取/写入/读取。我像这样打开手柄:

//Map the shared memory
     d_to_mbx_mem_arr[idx] = reinterpret_cast<Byte*>(MapViewOfFile(to_mem_h,    // handle to map object
                                                       FILE_MAP_ALL_ACCESS, // read/write permission
                                                       0,
                                                       0,
                                                       MAILBOX_SIZE_e));

此处设置的变量是一个 Byte* 数组(Byte 是 unsigned char 的别名),因此我进行了重新解释转换,因此我可以像使用标准 Byte 指针一样使用句柄。

后来我尝试通过以下方式释放手柄:

CloseHandle(d_to_mbx_mem_arr[p_tool_id]);
d_to_mbx_mem_arr[p_tool_id] = NULL;

由于在 CloseHandle 之后值被设置为 NULL 并且调用此方法的代码只是单线程的,我知道我只调用了一次。但是,当我调用它时,会收到以下警告:

“FMLib_Comm_Layer.exe 中 0x7c90e4ff (ntdll.dll) 的第一次机会异常:0xC0000008:指定了无效句柄。”

当我因警告而中断时,我看到它试图关闭的句柄的值为“0x01c90000”,这对我来说对于共享内存指针来说似乎是合理的。有没有人看到这个实现有问题,或者我应该假设我在其他地方搞砸了?

4

1 回答 1

4

您需要调用CloseHandle()on to_mem_h,而不是 on 的返回值MapViewOfFile()(请参见MapViewOfFile() 此处的使用示例——该示例调用UnmapViewOfFile()的返回值MapViewOfFile()并调用CloseHandle()的第一个参数MapViewOfFile()

于 2012-06-05T18:34:12.710 回答