开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 696|回复: 21
打印 上一主题 下一主题
收起左侧

[易语言纯源码] 【蠢新学汇编】取子程序指针 の 四种姿势

[复制链接]
结帖率:100% (3/3)
跳转到指定楼层
楼主
发表于 2025-4-13 00:48:01 | 只看该作者 回帖奖励 |正序浏览 |阅读模式   贵州省毕节市
分享源码
界面截图: -
是否带模块: 纯源码
备注说明: -
曾经走过的弯路 邀请大家一起走走


最方便的方法是安装汇编插件 直接就能取


之所以非得追求不用汇编插件的写法 是因为之前写的源码发给别人 别人跑不起来


有人不学汇编也不安装插件 所以就很麻


哪怕我写的代码是坨屎 我也要在屎上雕朵花再次优化如下↓


  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
下行地址子程序指针  
本层地址子程序指针  

子程序名返回值类型公开备 注
__启动窗口_创建完毕  
回调测试 (&套娃测试)
回调测试 (&首参测试)
下行地址 = 取下层测试地址 ()
回调测试 (下行地址)
本层测试 ({  })  ' 启动窗口创建完毕 执行一次 就可以了 里面套的参数值为0 就获取了再返回 不会继续执行 没有副作用
回调测试 (本层地址)
子程序名返回值类型公开备 注
回调测试  
参数名类 型参考可空数组备 注
回调指针子程序指针
变量名类 型静态数组备 注
计次整数型 
数组整数型0
计次循环首 (5, 计次)
加入成员 (数组, 计次)
调用子程序 (回调指针, , , 取变量地址 (数组))
计次循环尾 ()
子程序名返回值类型公开备 注
套娃测试  
参数名类 型参考可空数组备 注
参数一整数型
套娃 ({  })
子程序名返回值类型公开备 注
套娃 参数任意传 反正解套之后参数的指针会变成上层函数的参数指针
参数名类 型参考可空数组备 注
数组整数型参数可以是任意类型 非数值类/字节集 其他类型请传局部静态变量
解套 ()  ' 解套之后 本层子程序 局部变量 和 参数 等价于上层子程序
调试输出 (数组, “参 数”)
子程序名返回值类型公开备 注
解套 本层转上层
置入代码 ({ 93, 139, 109, 0, 195 })
' POP EBP
' MOV EBP,[EBP]
' RET
子程序名返回值类型公开备 注
首参测试  
参数名类 型参考可空数组备 注
参数一整数型
变量名类 型静态数组备 注
首变量整数型0如果存在其他局部变量 那就优先显式调用一次这个变量 因为易语言把第一个被调用的当成 [ebp-4]
首参到首变量_获取 ()
调试输出 (首变量, “变 量”)
首参到首变量_释放 ()
子程序名返回值类型公开备 注
首参到首变量_获取 首参须指针
置入代码 ({ 93, 139, 69, 8, 139, 0, 137, 69, 252, 195 })
' POP EBP
' MOV EAX,[EBP+8]
' MOV EAX,[EAX]
' MOV DWORD [EBP-4],EAX
' RET
子程序名返回值类型公开备 注
首参到首变量_释放 变量空指针
置入代码 ({ 139, 101, 0, 199, 68, 36, 252, 0, 0, 0, 0 })
' MOV ESP,[EBP]
' MOV DWORD [ESP-4],0
子程序名返回值类型公开备 注
取下层测试地址子程序指针 针对 参数为 字节集 数组 或者 自定义类型
变量名类 型静态数组备 注
数组整数型0
返回 (下层地址 ())  ' 除了局部自定义非静态 别的都能获取 因为局部非静态自定义数据会call一个 构造函数(自定义数据类型初始化)
下层测试 (数组)  ' 取指针的时候比另外三种麻烦 但是效率比另外三种高
子程序名返回值类型公开备 注
下层测试整数型 
参数名类 型参考可空数组备 注
参数一整数型
调试输出 (参数一, “下 层”)
返回 (0)
子程序名返回值类型公开备 注
下层地址子程序指针 返回(下层地址()) 所取子程序(须带参数,来源不限) 若传局部变量必须静态
置入代码 ({ 83, 81, 82, 139, 69, 4 })
' PUSH EBX
' PUSH ECX
' PUSH EDX
' MOV EAX,DWORD [EBP+4]
置入代码 ({ 64, 128, 56, 195, 117, 34, 128, 120, 255, 93, 117, 244, 128, 120, 254, 229, 117, 8, 128, 120, 253, 139, 117, 232, 235, 50 })
' 向下:
' INC EAX
' CMP BYTE[EAX],195
' JNE 带参
' 平栈:
' CMP BYTE[EAX-1],93
' JNE 向下
' CMP BYTE[EAX-2],229
' JNE 等价
' CMP BYTE[EAX-3],139
' JNE 向下
' JMP 向上
置入代码 ({ 128, 120, 254, 236, 117, 224, 128, 120, 253, 137, 117, 218, 235, 36 })
' 等价:
' CMP BYTE[EAX-2],236
' JNE 向下
' CMP BYTE[EAX-3],137
' JNE 向下
' JMP 向上
置入代码 ({ 128, 56, 194, 117, 211, 128, 120, 2, 0, 117, 205, 137, 193, 80, 49, 210, 49, 192, 138, 65, 1, 187, 4, 0, 0, 0, 247, 243, 88, 131, 250, 0, 117, 182, 235, 186 })
' 带参:
' CMP BYTE[EAX],194
' JNE 向下
' CMP BYTE [EAX+2],0
' JNE 向下
' MOV ECX,EAX
' PUSH EAX
' XOR EDX,EDX
' XOR EAX,EAX
' MOV AL,BYTE [ECX+1]
' MOV EBX,4
' DIV EBX
' POP EAX
' CMP EDX,0
' JNE 向下
' JMP 平栈
置入代码 ({ 72, 128, 56, 232, 117, 250, 128, 120, 251, 104, 117, 2, 235, 12 })
' 向上:
' DEC EAX
' CMP BYTE [EAX],232
' JNE 向上
' CMP BYTE[EAX-5],104
' JNE 传参
' JMP 找到
置入代码 ({ 128, 120, 253, 255, 117, 236, 128, 120, 254, 117, 117, 230, 139, 72, 1, 141, 76, 8, 5, 128, 57, 85, 117, 218 })
' 传参:
' CMP BYTE[EAX-3],255
' JNE 向上
' CMP BYTE[EAX-2],117
' JNE 向上
' 找到:
' MOV ECX,DWORD [EAX+1]
' LEA ECX,DWORD [EAX+ECX+5]
' CMP BYTE [ECX],85
' JNE 向上
置入代码 ({ 137, 200, 90, 89, 91, 201, 195 })
' MOV EAX,ECX
' POP EDX
' POP ECX
' POP EBX
' LEAVE
' RET
返回 (&下层地址)
子程序名返回值类型公开备 注
下层地址_简版子程序指针 返回(下层地址_简版()) 所取子程序(须带参数,且,来自局部) 需传静态变量
置入代码 ({ 81, 139, 69, 4, 64, 128, 56, 232, 117, 250, 128, 120, 251, 104, 117, 244, 139, 72, 1, 141, 76, 8, 5, 128, 57, 85, 117, 232, 137, 200, 89, 201, 195 })
返回 (&下层地址_简版)
' PUSH ECX
' MOV EAX, DWORD [EBP+4]
' 向下:
' INC EAX
' CMP BYTE[EAX],232
' JNE 向下
' CMP BYTE[EAX-5],104
' JNE 向下
' MOV ECX, DWORD [EAX+1]
' LEA ECX, DWORD [EAX+ECX+5]
' CMP BYTE [ECX],85
' JNE 向下
' MOV EAX, ECX
' POP ECX
' LEAVE
' RET
子程序名返回值类型公开备 注
本层测试  
参数名类 型参考可空数组备 注
参数一整数型
本层地址 (本层地址)  ' 本层地址 ( ) 里面的参数 数值为0就执行获取地址 取得地址之后绕行 非0则继续正常执行
调试输出 (参数一, “本 层”)
子程序名返回值类型公开备 注
本层地址 参数只接受 整数型 子程序指针
参数名类 型参考可空数组备 注
为零则取通用型程序集变量 或 全局变量
置入代码 ({ 139, 85, 8, 139, 2, 133, 192, 117, 53, 54, 139, 69, 0, 62, 139, 64, 4, 62, 3, 64, 252, 137, 2, 201, 90, 131, 196, 4 })
' MOV EDX,[EBP+8]
' MOV EAX,[EDX]
' TEST EAX,EAX
' JNE 不取
' MOV EAX, DWORD PTR SS:[EBP]
' MOV EAX, DWORD PTR DS:[EAX+4]
' ADD EAX, DWORD PTR DS:[EAX-4]
' MOV DWORD [EDX],EAX
' LEAVE
' POP EDX
' ADD ESP,4
置入代码 ({ 66, 128, 58, 139, 117, 250, 128, 122, 1, 229, 117, 244, 128, 122, 2, 93, 117, 238, 128, 122, 3, 195, 117, 2, 255, 226, 128, 122, 3, 194, 117, 224, 255, 226, 201, 194, 4, 0 })
' 循环:
' INC EDX
' CMP BYTE [EDX],139
' JNE 循环
' CMP BYTE [EDX+1],229
' JNE 循环
' CMP BYTE [EDX+2],93
' JNE 循环
' CMP BYTE [EDX+3],195
' JNE 有参
' JMP EDX
' 有参:
' CMP BYTE [EDX+3],194
' JNE 循环
' JMP EDX
' 不取:
' LEAVE
' RET 4



i支持库列表   支持库注释   
spec特殊功能支持库

来自群组: 热心网友

回调 传参.e

11.91 KB, 下载次数: 13, 下载积分: 精币 -2 枚

浪费精币 和上面的源码一模一样 就通用型可以跑得起来而已

评分

参与人数 2好评 +2 精币 +1 收起 理由
bianyuan456 + 1 + 1 支持开源~!感谢分享
多多帅吧 + 1 很赞同,谢谢!

查看全部评分


本帖被以下淘专辑推荐:

签到天数: 9 天

18
发表于 4 天前 | 只看该作者   辽宁省沈阳市
不明觉厉,谢谢分享!
回复 支持 反对

使用道具 举报

签到天数: 3 天

17
发表于 2025-4-22 08:39:37 | 只看该作者   广东省梅州市
支持开源~!感谢分享    支持开源~!感谢分享
回复 支持 反对

使用道具 举报

签到天数: 3 天

16
发表于 2025-4-18 11:50:55 | 只看该作者   广东省梅州市
    支持开源~!感谢分享    支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)
15
发表于 2025-4-15 13:23:21 | 只看该作者   湖南省邵阳市
66666666666666666666666
回复 支持 反对

使用道具 举报

签到天数: 3 天

14
发表于 2025-4-14 16:02:31 | 只看该作者   河北省石家庄市
        支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)

签到天数: 10 天

13
发表于 2025-4-14 07:54:00 | 只看该作者   山东省淄博市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:80% (4/5)
12
发表于 2025-4-14 01:20:06 | 只看该作者   山东省潍坊市
请问楼主,为啥我复制代码编译,提示
错误(4): 没有找到名为“通用型”的数据类型。
而直接下载你的源码,编译就能运行,为啥呢!?
通用型 的类型怎么会没有呢!?请楼主给我解答一下,我给楼主加精币!谢谢

点评

源码下载的下面有一行小字:"浪费精币 和上面的源码一模一样 就通用型可以跑得起来而已"   贵州省毕节市  发表于 2025-4-14 01:48
你把通用型 改成 子程序指针 或者 整数型 就可以了 我写通用型是为了兼容整数和子程序指针 你复制了 写死 指定其中任意一个也行   贵州省毕节市  发表于 2025-4-14 01:47
所以 我下面上传了一份源码啊 看源码下面的小字   贵州省毕节市  发表于 2025-4-14 01:46
回复 支持 反对

使用道具 举报

结帖率:80% (4/5)
11
发表于 2025-4-14 01:13:50 | 只看该作者   山东省潍坊市
已经顶贴,感谢您对论坛的支持!
回复 支持 反对

使用道具 举报

10
发表于 2025-4-13 20:34:14 | 只看该作者   江苏省连云港市

感谢分享
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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