开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 627|回复: 0
收起左侧

[求助] 求助一个关于变量数据地址的问题

[复制链接]
结帖率:97% (36/37)
发表于 2022-11-27 09:16:40 | 显示全部楼层 |阅读模式   江西省南昌市
如题,在做一个东西的时候遇到了一个小问题

1.jpg
在子程序外面 整数1=132654,然后取得变量数据地址为 132645
然后将 整数1 作为参数传入了子程序
子程序(整数1)
在子程序里面取得的变量数据地址为 5767473
地址为什么会发生改变?
而且好像就整数型会出现这个问题,文本型倒是不会

  
子程序名返回值类型公开备 注
通用型_取变量数据地址整数型 
参数名类 型参考可空数组备 注
变量通用型
变量名类 型静态数组备 注
数据类型整数型 
数据类型 = 通用型_取类型 (变量)
如果真 (数据类型 = 0)
置入代码 ({ 139, 69, 8, 139, 0, 201, 194, 4, 0 })
' mov eax,[ebp+8]
' mov eax,[eax]
' leave
' retn 0x0004
如果真 (数据类型 = 1)
置入代码 ({ 139, 69, 8, 201, 194, 4, 0 })
' mov eax,[ebp+8]
' leave
' retn 0x0004

如果真 (数据类型 = 2)
置入代码 ({ 139, 69, 8, 139, 0, 201, 194, 4, 0 })
' mov eax,[ebp+8]
' mov eax,[eax]
' leave
' retn 0x0004
如果真 (数据类型 = 3)
置入代码 ({ 139, 69, 8, 139, 0, 131, 192, 8, 201, 194, 4, 0 })
' mov eax,[ebp+8]
' mov eax,[eax]
' Add eax,8
' leave
' retn 0x0004
如果真 (数据类型 = 5)
置入代码 ({ 139, 69, 8, 139, 0, 201, 194, 4, 0 })
' mov eax,[ebp+8]
' mov eax,[eax]
' leave
' retn 0x0004
返回 (0)

  
子程序名返回值类型公开备 注
通用型_取类型整数型 返回通用型变量的实际类型,改自“为你芯冻”的代码,返回值:0.自定义类型 1.数值类型 2.文本型 3.字节集 4.数组 5.函数指针
参数名类 型参考可空数组备 注
变量通用型注:经测试该函数不是很准确 有可能会误判 仅供参考 请慎用,具体的可能出现的误判请看源码解释说明!
变量名类 型静态数组备 注
m整数型 
c整数型 
' !!注:经测试该函数不是很准确 有可能会误判 仅供参考 请慎用
' 自定义类型 函数指针 这两种判定得比较准确 因为内存中的特征较多
' 文本型可能会被误判为数组或数值
' 传来参数如果实际为的数值类型 但其如果恰表示一个指针 则也容易被误判为其他类型
置入代码 ({ 139, 69, 8, 137, 69, 252, 80 })
' mov eax, dword [ebp+0x08]
' mov dword [ebp-0x04], eax
' push eax
如果真 (IsBadReadPtr (m, 4) ≠ 0)
返回 (1)
置入代码 ({ 88, 139, 0, 137, 69, 248 })
' pop eax
' mov eax, dword [eax]
' mov dword [ebp-0x08], eax
如果真 (c ≠ 1)
c = GlobalSize (m)
如果真 (c = 0)
置入代码 ({ 139, 69, 252, 139, 0, 129, 224, 255, 255, 255, 0, 137, 69, 248 })
' mov eax, dword [ebp-0x04]
' mov eax, dword [eax]
' and eax, 0x00FFFFFF
' mov dword [ebp-0x08], eax
返回 (选择 (c = 5461846 c = 15042901, 5, 2))
返回 (0)
c = GlobalSize (m)
如果真 (c ≠ 0)
置入代码 ({ 139, 69, 252, 139, 64, 4, 137, 69, 252 })
' mov eax, dword [ebp-0x04]
' mov eax, dword [eax+0x04]
' mov dword [ebp-0x04], eax
c = c - 8
返回 (选择 (m = c, 3, 4))
返回 (3)



补充内容 (2022-11-27 10:06):
已自行解决!
  高级模式
B Color Image Link Quote Code Smilies |上传

本版积分规则 致发广告者

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

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

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