.版本 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
|