【发布时间】:2013-09-13 22:11:26
【问题描述】:
我正在编写一个小型内存扫描应用程序来查找内存中的指针。
但我似乎没有得到预期的结果。
我有以下代码:
[DllImport("kernel32.dll")]
private static extern bool ReadProcessMemory(IntPtr hProcess, IntPtr lpBaseAddress, [Out] byte[] buffer, UInt32 size, IntPtr lpNumberOfBytesRead);
public int ReadInt(long Address)
{
byte[] buffer = new byte[4];
ReadProcessMemory(ProcessHandle, (IntPtr)Address, buffer, 4, IntPtr.Zero); // this always returns true
return BitConverter.ToInt32(buffer, 0);
}
public List<long> SearchInt(long start, long end, int value)
{
List<long> results = new List<long>();
for (long i = start; i < end; i++)
{
try
{
if (ReadInt(i) == value)
results.Add(i);
}
catch (Exception)
{
break; // no exceptions occur
}
}
return results;
}
如果我这样调用方法:
SearchInt(baseAddress.ToInt64(), lastAddress.ToInt64(), 1234)
我知道我正在读取的进程有一个值为 1234 的整数,但我没有得到任何结果。如果我扫描其他值,有时会得到结果。
baseAddress 是 process.MainModule.BaseAddress
和lastAddress 是 baseAddress + process.MainModule.ModuleMemorySize
我错过了什么吗?
【问题讨论】:
-
您正在隐藏异常。至少使用 Debug.WriteLine() 记录它们,这样您就可以查看循环是否由于异常而提前退出。
-
没有例外。
-
在 64 位处理器上,
i++将“跳跃”8 个字节。 -
我应该怎么做?
-
不,它不会将 i 加一,然后将其用作地址加一字节。
标签: c# pointers memory readprocessmemory