所有,这是对上一个问题的跟进:C#formatting external Dll function parameters
这里特别是我试图转换为 C# 的代码:
FILES_GetMemoryMapping((LPSTR)(LPCTSTR)MapFile, &Size, (LPSTR)MapName, &PacketSize, pMapping, &PagePerSector);
// Allocate the mapping structure memory
pMapping = (PMAPPING)malloc(sizeof(MAPPING));
pMapping->NbSectors = 0;
pMapping->pSectors = (PMAPPINGSECTOR) malloc((Size) * sizeof(MAPPINGSECTOR));
// Get the mapping info
FILES_GetMemoryMapping((LPSTR)(LPCTSTR)MapFile, &Size, (LPSTR)(LPCTSTR)MapName, &PacketSize, pMapping, &PagePerSector);
函数“FILES_GetMemoryMapping”被调用了两次,我猜第一次是获取结构的大小,第二次是实际填充它。
“pMapping”是指向 C++ 中结构的指针,在我的 C# 代码中,我将 pMapping 作为 IntPtr 类型。下一行我可以转换为:
pMapping = Marshal.AllocHGlobal(Marshal.SizeOf(new UM0516.Mapping()));
以 (UM0516.Mapping) 为结构。很酷,所以我刚刚分配了一些 IntPtr 指向的空间。现在是下一行...“pMapping->NbSectors = 0;”
我应该如何进入现在分配的非托管内存空间,将其类型转换为 (UM0516.Mapping) 结构,并设置其成员之一?然后确保我没有搞砸太多,这样我第二次调用“FILES_GetMemoryMapping”时,它现在可以使用这个结构了吗?
-- 好的,我接受了一些建议,现在有了这个:
我试过了,在第一次“FILES_GetMemoryMapping”调用时出现“AccessViolationException 未处理”异常
这是我所拥有的:
string filepath = @"C:\blah.blah";
string MapFile = @"D:\blah.blah";
UM0516.Mapping myMapping = new UM0516.Mapping();
IntPtr pMapping = Marshal.AllocHGlobal(Marshal.SizeOf(myMapping));
Marshal.StructureToPtr(myMapping, pMapping, false);
ushort PacketSize = 0;
ushort size = 0;
string MapName = String.Empty;
byte PagePerSector = 0;
uint b7 = UM0516.FILES_GetMemoryMapping(MapFile, out size, MapName, out PacketSize, pMapping, out PagePerSector);
你认为这个异常来自“pMapping”参数吗?这可能来自我传递的其他任何东西吗?