【发布时间】:2012-06-05 18:23:40
【问题描述】:
在我的应用程序中,我打开了一个共享内存的句柄,我可以从中读取/写入。我这样打开手柄:
//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”,这对我来说对于共享内存指针来说似乎是合理的。有没有人看到这个实现有问题,或者我应该假设我在其他地方搞砸了?
【问题讨论】:
-
两个问题:(1)那个句柄值和你第一次获取句柄时得到的值是一样的吗? (2) 你打电话给
UnmapViewOfFile电话成功了吗? [你调用UnmapViewOfFile和CloseHandle的顺序无关紧要,但你必须调用他们两个来释放文件。不过,两者都应该成功。]
标签: c++ windows shared-memory handles