c# - 更改进程的基址指针

标签 c# c++ windows memory


我有一个关于指针和内存分配的更理论化的问题。
比方说我有一个正在运行的进程,它分配了从 0x01 到 0x03 的 2 个字节。
如果我想从该内存中读取,我可能会使用 ReadProcessMemory。
但是我具体应该给出什么指针?
它是相对指针还是绝对指针?
可以说这个指针是相对的,所以我用指向 0x00 的指针调用 ReadProcessMemory。
但是 Windows 是如何知道进程内存从哪里开始到哪里结束的呢?
Windows 是否不必保存内存属于(或由其分配)进程的地址?
但是 Windows 在哪里保存这些信息以及它如何知道它保存信息的位置?
我听说过一种叫做“基本指针”的东西。我想这就是我要找的。
内存属于进程的地方。
好的,但现在假设我想将某个进程的内存复制到某个地方(也许是 HDD?),以便暂时清理我的内存。然后我想把内存放回原来的位置,但我不能告诉 Windows“从 0x00c 分配 2048 字节到 0x80c”。
我必须说“在某处分配 2048 字节”,然后 Windows 告诉我“某处”的位置' 是。
但是如果我再次重新启动我的应用程序,我将不得不告诉它“你好进程,你的整个内存不再是 0x01,它现在是 0x0c”。
有什么方法可以做到这一点吗?也许是 c# 或 c++,或者只是一个意见(这又是一个理论问题。无关好坏,只是有可能吗?)。

最佳答案

OK, but now let's say I want to copy the memory of a process somewhere (HDD maybe?) to clean up my memory for a little while. Then I want to put memory back where it was before, but I cant tell windows 'allocate 2048 bytes from 0x00c to 0x80c'.

只需自己分配内存即可。 Windows是一个虚拟内存系统。如果它不能将内容放入物理内存,那么它只会将内存分页回磁盘。您不需要做任何工作来导致这种情况发生。

编辑:在对评论的更多回应中,如果您想实际解除分配其他进程使用的内存,那您就完全不走运了。您无法可靠地确定目标进程如何使用该内存,并且您可能会由于访问冲突而导致目标进程立即终止。

此外,Windows NT 及其衍生产品上的所有内存分配都归结为 VirtualAlloc 函数,这些函数只能在调用进程的上下文中使用——您不能强制其他进程为您做这件事。

我想你可以自己编写一个内核驱动程序,它将随机垃圾写入内存管理器,让它做你想做的事,但至少你会导致目标进程失败,并且很可能导致目标进程失败整个系统。

但是,您的问题从根本上讲没有意义,因为 Windows 已经做出了类似的决定,将进程的内存移出到磁盘。 Windows 是 virtual memory系统,并且特定的内存位置仅在现有进程的上下文中才有意义。

关于c# - 更改进程的基址指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4350328/

相关文章:

c# - ASP .net Web Api 下载和查看图片

c++ - 实现循环缓冲区以在一次调用中写入/读取任意数量的数据

.net - .NET (wpf) 应用程序的内存管理

c - 进程返回 -1073741819 <0xC0000005>

c# - Windows 服务任务 - 轮询取消

c# - SslStream 身份验证在本地系统帐户下失败

c++ - Chrome 使用移动用户代理不工作

c - 如何在Windows中获取操作系统名称,版本?

c# - MVC 访问应用程序设置

c++ - 将 const 模式写入特定大小的文件