精易论坛

标题: 堆栈xx 处理理解 这里写了两个 双精度汇编加法做对比 [打印本页]

作者: cf2006a    时间: 2020-2-25 20:59
标题: 堆栈xx 处理理解 这里写了两个 双精度汇编加法做对比
.版本 2
.支持库 spec
.子程序 __启动窗口_创建完毕
.局部变量 a, 双精度小数型
.局部变量 b, 双精度小数型
a = 18888.8
b = 588888888.8
调试输出 (“堆栈”, 加法_双精度_参数中计算 (a, b), a, b)
调试输出 (“参数”, 加法_双精度_参数中计算 (a, b), a, b)
编辑框2.内容 = 到文本 (地址_子程序真实 (&加法_双精度_堆栈中计算))
.子程序 地址_子程序真实, 整数型, 公开
.参数 参_地址, 子程序指针
置入代码 ({ 83, 81, 139, 69, 8, 64, 139, 8, 128, 249, 232, 117, 248, 139, 72, 1, 141, 92, 8, 5, 139, 11, 193, 225, 8, 129, 249, 0, 85, 139, 236, 141, 64, 4, 117, 225, 137, 216, 89, 91, 201, 194, 4, 0 })
返回 (0)
.子程序 加法_双精度_堆栈中计算, 双精度小数型, 公开
.参数 参_加数, 双精度小数型, , 8
.参数 参_被加数, 双精度小数型, , c + 4 = 10
置入代码 ({ 221, 69, 8, 220, 69, 16, 221, 93, 248, 139, 85, 252, 139, 69, 248, 137, 236, 93, 194, 16, 0 })
返回 (参_加数 + 参_被加数)  ' 这里不会执行用来标注看的
' //push ebp
' //mov ebp, esp
' //sub esp, 0x00000008
' 以上三行是易语言自行添加上去的
' fld qword [ebp+0x08]                第一个参数从 8  到 c   八个字节  属于第一个参数
' fadd qword [ebp+0x10]               第二个参数从 10 到 14  八个字节  属于第二个参数
' fstp qword [ebp-0x08]               ebp-0x08 是局部变量地址 或者说堆栈地址   ebp-0x04 到 ebp-0x08    应该是把参数的值复制到局部变量里 压进去准备运算  这里压的是  ebp-0x08  而不是 ebp-0x04  变量是在堆栈中的运算的所以是后进先出(或者是倒着保存)
' mov edx, dword [ebp-0x04]           局部变量的开始地址给 edx
' mov eax, dword [ebp-0x08]           把第二个 4 字节地址给 eax 返回
' mov esp, ebp                        以下平衡堆栈
' pop ebp
' retn 0x0010                         这里两个双精度参数一个双精度 长度为8字节  8+8 16 所以  retn 0x10  也就是十进制的16

.子程序 加法_双精度_参数中计算, 双精度小数型, 公开
.参数 参_加数, 双精度小数型, , 8
.参数 参_被加数, 双精度小数型, , c + 4 = 10
置入代码 ({ 221, 69, 8, 220, 69, 16, 221, 93, 8, 139, 85, 12, 139, 69, 8, 137, 236, 93, 194, 16, 0 })
返回 (参_加数 + 参_被加数)  ' 这里不会执行用来标注看的
' //push ebp
' //mov ebp, esp
' //sub esp, 0x00000008
' 以上三行是易语言自行添加上去的
' fld qword [ebp+0x08]                第一个参数从 8  到 c   八个字节  属于第一个参数
' fadd qword [ebp+0x10]               第二个参数从 10 到 14  八个字节  属于第二个参数
' fstp qword [ebp+0x08]               ebp+0x08  和堆栈那个 地址是相反的    不是把 0x0c 先压进去 而是把 0x08 压进去计算
' 堆栈中计算                          ebp-0x08 是局部变量地址 或者说堆栈地址   ebp-0x04 到 ebp-0x08    应该是把参数的值复制到局部变量里 压进去准备运算  这里压的是  ebp-0x08  而不是 ebp-0x04  变量是在堆栈中的运算的所以是后进先出(或者是倒着保存)
' mov edx, dword [ebp+0x0C]           这里取出地址也是 和堆栈那个相反的 是把0x0c给edx 而不是 0x08给edx
' mov eax, dword [ebp+0x08]
' mov esp, ebp                        以下平衡堆栈
' pop ebp
' retn 0x0010                         这里两个双精度参数一个双精度 长度为8字节  8+8 16 所以  retn 0x10  也就是十进制的16


作者: 逃离梦境    时间: 2020-2-25 21:07
哦哦 感谢楼猪分享
作者: q1599273319    时间: 2020-2-25 21:14
参数 参_地址, 子程序指针
作者: QQ协议    时间: 2020-2-26 08:35
参数 参_地址, 子程序指针参数 参_地址, 子程序指针
作者: zhifu3158    时间: 2022-1-20 02:16
两个 都没有核心库快!但是汇编的整数型 加法  速度比核心库快很多




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4