|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
C++论坛
→
『 C++教室 』
→ 取内存中字符串长度的问题
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
1200
人关注过本帖
标题:
取内存中字符串长度的问题
只看楼主
加入收藏
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
楼主
收藏
问题点数:0 回复次数:9
取内存中字符串长度的问题
DWORK MemAddrtemp=0x12345678;
//MemAddrtemp 存放字符串一级指针
ReadProcessMemory(processH,(LPCVOID)MemAddrtemp,&MemAddrtemp,4,&byread);
//用ReadProcessMemory 读取到字符串变量首地址,再次存入MemAddrtemp
之后要怎么才能取得MemAddrtemp指向的字符串长度?
搜索更多相关主题的帖子:
字符串
2011-03-18 21:27
举报帖子
使用道具
赠送鲜花
hahayezhe
来 自:湖南张家界
等 级:
贵宾
威 望:
24
帖 子:1386
专家分:6999
注 册:2010-3-8
第
2
楼
收藏
得分:0
确定C风格么?
_tcslen((char*)MemAddrtemp);
2011-03-18 21:36
举报帖子
使用道具
赠送鲜花
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
第
3
楼
收藏
得分:0
能通过编译但运行后,直接内存错误,是什么问题呢
2011-03-18 21:51
举报帖子
使用道具
赠送鲜花
hahayezhe
来 自:湖南张家界
等 级:
贵宾
威 望:
24
帖 子:1386
专家分:6999
注 册:2010-3-8
第
4
楼
收藏
得分:0
0x12345678 该地址是什么?
你确定是个字符串的首地址 末尾用\0结束
你确定指向的内存是可读的?!
2011-03-18 21:52
举报帖子
使用道具
赠送鲜花
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
第
5
楼
收藏
得分:0
DWORD MemAddrtemp=0x12345678,byread;
char gamename[]="同在一天空下吧";
ReadProcessMemory(processH,(LPCVOID)MemAddrtemp,&MemAddrtemp,4,&byread);
ReadProcessMemory(processH,(LPCVOID)MemAddrtemp,&MemAddrtemp,4,&byread);
MemAddrtemp+=0x24;
ReadProcessMemory(processH,(LPCVOID)MemAddrtemp,&MemAddrtemp,4,&byread);
_tcslen((char*)MemAddrtemp)
地址应该没错,不加字符长度判断能写入.
[
本帖最后由 sunstarmail 于 2011-3-18 23:25 编辑
]
2011-03-18 21:58
举报帖子
使用道具
赠送鲜花
hahayezhe
来 自:湖南张家界
等 级:
贵宾
威 望:
24
帖 子:1386
专家分:6999
注 册:2010-3-8
第
6
楼
收藏
得分:0
你是从别的进程中读数据!
你确定那个进程的变量是全局的?
你确定每次启动时地址都不变?!
2011-03-18 22:01
举报帖子
使用道具
赠送鲜花
hahayezhe
来 自:湖南张家界
等 级:
贵宾
威 望:
24
帖 子:1386
专家分:6999
注 册:2010-3-8
第
7
楼
收藏
得分:0
还有你以为你MemAddrtemp的地址是别的进程的 就能访问了 ?
你调用MemAddrtemp时里面的数据一定是指向本地的!
你要讲对方的那段数据内存拷过来才行
(_tcslen((char*)MemAddrtemp)里的MemAddrtemp指向本进程 并不是你读的那个进程!
2011-03-18 22:05
举报帖子
使用道具
赠送鲜花
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
第
8
楼
收藏
得分:0
0x0061B034是基地址,经过几次指针,MemAddrtemp储存的地址最后和远程程序字符串首地址对应,字符串后是00结尾
2011-03-18 22:09
举报帖子
使用道具
赠送鲜花
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
第
9
楼
收藏
得分:0
以下是引用
hahayezhe
在2011-3-18 22:05:37的发言:
还有你以为你MemAddrtemp的地址是别的进程的 就能访问了 ?
你调用MemAddrtemp时里面的数据一定是指向本地的!
你要讲对方的那段数据内存拷过来才行
(_tcslen((char*)MemAddrtemp)里的MemAddrtemp指向本进程 并不是你读的那个进程!
有办法能读取远程进程吗?
2011-03-18 22:13
举报帖子
使用道具
赠送鲜花
sunstarmail
等 级:
新手上路
帖 子:6
专家分:0
注 册:2008-9-17
第
10
楼
收藏
得分:0
谢谢,明白.刚才晕头了
2011-03-18 23:23
举报帖子
使用道具
赠送鲜花
10
1/1页
1
快速回复:
取内存中字符串长度的问题
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.017505 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved