挑战高手

hex 2000-09-24 12:19:00
最近用"金山游侠2",发现一个技术问题:
如何才能获得某个正在运行的程序在内存中的地址范围?用vc如何实现?
如果不能做到,谁能解释一下,金山游侠2的扫描内存功能是如何工作的?
...全文
160 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
hex 2000-09-28
  • 打赏
  • 举报
回复
谢谢
土豆 2000-09-26
  • 打赏
  • 举报
回复
1.用Process32First和Process32Next可以玫举所有的进程(Window95/98实现了,WINNT4.0以及一下没有实现,Win2000实现了,如果是用NT4的话,就比较麻烦了,要用Performanance Data,太麻烦了,不说了。)

2.用VirtualQueryEx可以得到一个进程的内存的信息,如开始地址等(95/98/NT4/2000都实现了,就NT3.5没实现,要自己写,很麻烦的,不说了,如果感兴趣,给你源代码。)

3.然后用ReadProcessMemory和WriteProcessMemory就可以实现对某一进程内存的修改,这两个函数95/98/NT4/2000都实现了,读和写的方式是通过ReadPorcessMemory将内存块读到本进程中,就是在本进程上的一个拷贝,然后对这个拷贝执行各种操作,反正是在本进程中地一个拷贝(本进程中的一片内存),随你怎么操作啦,再将内存块用WriteProcessMemory写回去,就实现了对该内存数据的修改,象金山游侠、FPE那样的操作实际都是先对在本进程中的拷贝进行操作,然后将拷贝写回去。
hex 2000-09-26
  • 打赏
  • 举报
回复
请问还有没有其他方法得到正在运行程序名称及其内存地址的范围。
Holly 2000-09-24
  • 打赏
  • 举报
回复
你去查找一下Toolhelp32ReadProcessMemory和有关Tool Help 功能的资料,在MSDN中都有,另外还需要有关Virtual Memory的一些资料!
lu0 2000-09-24
  • 打赏
  • 举报
回复
内存引用无非就是HEAP,栈,DATA节.

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧