社区
C++ 语言
帖子详情
内存地址?
bingbingliangliang
2005-12-08 02:09:54
为什么用工具在内存查找某程序文本框里的内容得到的偏移地址总是在变化。也就是每次打开这个程序查找的到的地址都不一样。我想通过修改内存修改它的值。
...全文
350
16
打赏
收藏
内存地址?
为什么用工具在内存查找某程序文本框里的内容得到的偏移地址总是在变化。也就是每次打开这个程序查找的到的地址都不一样。我想通过修改内存修改它的值。
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
16 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
bingbingliangliang
2005-12-19
打赏
举报
回复
晨曦什么意思?
bingbingliangliang
2005-12-18
打赏
举报
回复
偏移地址怎么找到?请帮帮忙。
csucdl
2005-12-18
打赏
举报
回复
按道理, 偏移地址应该没有改变啊, 只是当程序装入内存的时候, 操作系统给他分配的代码段的基址不是一个已知的值
watermelontx
2005-12-18
打赏
举报
回复
用汇编用吧..
bingbingliangliang
2005-12-18
打赏
举报
回复
谢谢!我明白了
bingbingliangliang
2005-12-18
打赏
举报
回复
怎么找到内存地址?
SnowwhiteYqw
2005-12-18
打赏
举报
回复
在DOS下,访问内存的指针是用段地址:偏移量来表示,所有程序共用一个内存空间,由低向高分配内存空间,所以任何程序都可以随便修改内存中的数据,包括不属于自己程序的内存空间和中断向量表。而且所有程序被局限在1M的基本内存(Base Memory)中,不能直接访问扩充内存。对于Windows下的程序来说,它所访问的内存地址不再是真实的。而是虚拟的、独立的全平坦式(flat)的内存空间。如一个32位的程序可访问内存地址是0x00000000到0xffffffff(4G),指针不再存储段地址。
我们可以用: DWORD VirtualQuery( LPCVOID lpAddress, // 内存地址 PMEMORY_BASIC_INFORMATION lpBuffer, // 内存地址信息 DWORD dwLength // lpBuffer 的大小,也就是结构 MEMORY_BASIC_INFORMATION 的大小 ); 来得到某个内存块的状态。使用 VirtualQueryEx() 还可以访问其它进程的内存分配信息。
ReadProcessMemory()、WriteProcessMemory()。这两个函数可以直接对其它进程的内存进行读写操作。
bingbingliangliang
2005-12-09
打赏
举报
回复
问题还是没解决,请帮忙。
HellotoYou
2005-12-08
打赏
举报
回复
将内存锁定
qinxiaolin
2005-12-08
打赏
举报
回复
在windows 里面你每次每次打开的时候,所处的内存地址是随机的!
建议看看PE文件格式!
bingbingliangliang
2005-12-08
打赏
举报
回复
可是我得找到了地址才能用ReadProcessMemory()、WriteProcessMemory()呀关键是找不对地址呀
每次打开地址都在变。
guoxiaoli
2005-12-08
打赏
举报
回复
windows 有自己的内存分配机制!
在DOS下,访问内存的指针是用段地址:偏移量来表示,所有程序共用一个内存空间,由低向高分配内存空间,所以任何程序都可以随便修改内存中的数据,包括不属于自己程序的内存空间和中断向量表。而且所有程序被局限在1M的基本内存(Base Memory)中,不能直接访问扩充内存。对于Windows下的程序来说,它所访问的内存地址不再是真实的。而是虚拟的、独立的全平坦式(flat)的内存空间。如一个32位的程序可访问内存地址是0x00000000到0xffffffff(4G),指针不再存储段地址。
我们可以用: DWORD VirtualQuery( LPCVOID lpAddress, // 内存地址 PMEMORY_BASIC_INFORMATION lpBuffer, // 内存地址信息 DWORD dwLength // lpBuffer 的大小,也就是结构 MEMORY_BASIC_INFORMATION 的大小 ); 来得到某个内存块的状态。使用 VirtualQueryEx() 还可以访问其它进程的内存分配信息。
ReadProcessMemory()、WriteProcessMemory()。这两个函数可以直接对其它进程的内存进行读写操作。
bingbingliangliang
2005-12-08
打赏
举报
回复
那如果想在内存中修改它的值怎么做?
屋顶上的老猫
2005-12-08
打赏
举报
回复
偏移地址变动是windows系统的内存管理机制,你人为是控制不来的,不过在DOS里就OK了!
maxzhk
2005-12-08
打赏
举报
回复
你两次查找之间这个文本框所在的窗口已经被关闭后再打开,或者其他事件已经让它销毁了又再申明了一次过了?
如果有这样的过程,那当它被再次申明的时候肯定不会再是同一个地址了
小弟愚见,来此抛砖引玉,期待各位高手高见,呵~
jlu3389
2005-12-08
打赏
举报
回复
系统随机分配的内存,可能是这个原因
查看内存使用情况的汇编源代码
查看内存使用情况的汇编源代码
C++八股文——内存管理(堆和栈的区别? C++内存分区? 内存泄漏?如何避免?什么是智能指针?有哪些种类? 什么是野指针,怎么产⽣的,如何避免 ? 野指针和悬浮指针的区别? 内存对齐是什么?)
C++内存管理 堆和栈的区别 C++内存分区 内存泄漏?如何避免? 1、什么是内存泄露? 2、内存泄漏的分类 3、什么操作会导致内存泄露? 4、如何防⽌内存泄露? 5、智能指针有了解哪些? 6、构造函数,析构函数要设为虚函数吗,为什么? 什么是智能指针?有哪些种类? new 和 malloc 有什么区别? delete 和 free 有什么区别? 什么是野指针,怎么产⽣的,如何避免 野指针和悬浮指针的区别 内存对齐是什么?为什么需要考虑内存对齐? 1、什么是内存对齐 2、为什么需要考虑内存对⻬ 测试题⽬
大学计算机一条指令的执行过程实验,实验4 一条指令的执行过程 实验报告(4页)-原创力文档...
实验4??一条指令的执行过程??实验报告学号????????????姓名??????????? ???????班级:??? ?????????实验时间:? ????年??月??日??实验报告表4-1???一条指令执行过程记录表步骤1???用户指定两个加数加数1,加数2?PC中存储的指令地址?RAM中对应指令地址中的指令编码?RAM中加数一的编码与
内存地址
?RAM中加数一的编码与
内存地址
?步骤2? ...
什么是内存泄露?怎么检测
来源:https://blog.csdn.net/u014796694/article/details/80795372 什么是内存泄露? 简单地说就是申请了一块内存空间,使用完毕后没有释放掉。它的一般表现方式是程序运行时间越长,占用内存越多,最终用尽全部内存,整个系统崩溃。由程序申请的一块内存,且没有任何一个指针指向它,那么这块内存就泄露了。 2、如何检测内存泄露 第一:良好的编码习惯,...
什么是内存对齐?为什么要内存对齐?
要了解为什么要内存对齐,首先我们要了解什么是内存对齐 什么是内存对齐 关于什么是内存对齐,我们先来看几个例子 typedef struct { int a; double b; short c; }A; typedef struct { int a; short b; double c; }B; 分别对他们求大小,sizeof(A),si...
C++ 语言
65,187
社区成员
250,526
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章