开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 235|回复: 4
收起左侧

[已解决] __get_byte 疑问

 关闭 [复制链接]
结帖率:95% (18/19)
发表于 2024-11-14 01:03:13 | 显示全部楼层 |阅读模式   福建省宁德市
14精币
这是精易模块中的一个函数,返回指针地址处的一个字节。
有一个疑点,就是mov eax,[eax+ebx],此处是使用的dword类型读取的,也就是读了4字节,储存在eax寄存器,然后返回,假设内存大小只有1字节,这里读4字节不就越界读取了?,这样的操作不会有问题吗?虽然大多数情况下不会出问题,我也没遇到过出问题的情况,仅是以此为例提出提问,这种情况下的越界读取是否会存在导致程序崩溃的情况?
  
子程序名返回值类型公开备 注
__get_byte字节型 请确保指针的合法性,读取内存
参数名类 型参考可空数组备 注
lpAddr整数型内存地址
offset整数型偏移
置入代码 ({ 139, 69, 8, 139, 93, 12, 139, 4, 24, 201, 194, 8, 0 })
' mov eax,[ebp+8]
' mov ebx,[ebp+12]
' mov eax,[eax+ebx]
' leave
' ret 8
返回 (0)



最佳答案

查看完整内容

也可以是这样,具体哪个性能更优秀我也不清楚,但是结果是一样 .版本 2 .子程序 __get_byte, 字节型, 公开, 请确保指针的合法性,读取内存 .参数 lpAddr, 整数型, , 内存地址 .参数 offset, 整数型, , 偏移 置入代码 ({ 139, 69, 8, 139, 93, 12, 138, 4, 24, 201, 194, 8, 0 }) ' mov eax, dword [ebp+0x08] ' mov ebx, dword [ebp+0x0C] ' mov al, byte [eax+ebx] ' leave ' retn 0x0008 返回 (0) ...

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

结帖率:100% (4/4)

签到天数: 21 天

发表于 2024-11-14 01:03:14 | 显示全部楼层   福建省龙岩市
也可以是这样,具体哪个性能更优秀我也不清楚,但是结果是一样

  
子程序名返回值类型公开备 注
__get_byte字节型 请确保指针的合法性,读取内存
参数名类 型参考可空数组备 注
lpAddr整数型内存地址
offset整数型偏移
置入代码 ({ 139, 69, 8, 139, 93, 12, 138, 4, 24, 201, 194, 8, 0 })
' mov eax, dword [ebp+0x08]
' mov ebx, dword [ebp+0x0C]
' mov al, byte [eax+ebx]
' leave
' retn 0x0008
返回 (0)

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (4/4)

签到天数: 21 天

发表于 2024-11-14 01:16:06 | 显示全部楼层   福建省龙岩市
你这个用于读1字节的数据确实可能会越界,但不一定会崩溃,可能会返回一个错误的值,可以把取值用的mov改成movzx,这样就只会读取一个字节了

  
子程序名返回值类型公开备 注
__get_byte字节型 请确保指针的合法性,读取内存
参数名类 型参考可空数组备 注
lpAddr整数型内存地址
offset整数型偏移
置入代码 ({ 139, 69, 8, 139, 93, 12, 15, 182, 4, 24, 201, 194, 8, 0 })
' mov eax, dword [ebp+0x08]
' mov ebx, dword [ebp+0x0C]
' movzx eax, byte [eax+ebx]
' leave
' retn 0x0008
返回 (0)

补充内容 (2024-11-14 01:34):
说错了,你这并不会返回错误的值,但是如果你读取的正好是内存页边缘的话那确实会崩溃
回复

使用道具 举报

结帖率:60% (3/5)

签到天数: 22 天

发表于 2024-11-14 01:20:00 | 显示全部楼层   广西壮族自治区柳州市
内存大小不可能只有1字节,内存页是4KB对齐,也就是最小4096字节,这个读到边界超出范围应该会崩,一般不会发生读到边界的情况,因为数据不会巧到把所有页存满
回复

使用道具 举报

结帖率:100% (3/3)

签到天数: 22 天

发表于 2024-11-14 01:45:59 | 显示全部楼层   福建省莆田市
做个实验,死循环无限读取不同的地址,等个几小时,解除你的疑惑
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表