在我的应用程序中,我打开了一个共享内存的句柄,我读取/写入/读取。我像这样打开手柄:
//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”,这对我来说对于共享内存指针来说似乎是合理的。有没有人看到这个实现有问题,或者我应该假设我在其他地方搞砸了?