addr
.386.model flat,stdcall
option casemap:none
.stack 4096
.data
ExitProcess PROTO,dwExitCode:DWORD
Array DWORD 1,2,3,4,5
.code
AddTwo Proc dwParam1:DWORD
enter 0,0
;================================
mov eax,
;===============================
leave
ret
AddTwo endp
main PROC
mov ebx,OFFSET Array
INVOKE AddTwo,ADDR Array
;能自动把参数压栈
;能检查参数的个数是否正确
INVOKE ExitProcess,0
main ENDP
END main
我的问题:ADDR Array 压入变量Array的地址(压倒ebp+8),所以eax=ebx,可是实际不相等如图
你的问题出在 `mov eax,` 这一行。这里应该将 `Array` 的地址赋值给 `eax` 寄存器,而不是留空。正确的代码应该是这样的:
mov eax, OFFSET Array
这样就能将 `Array` 的地址赋值给 `eax` 寄存器。然后你可以在 `AddTwo` 过程中使用 `eax` 来操作 `Array`。
另外,关于你的疑问,实际上 `eax` 和 `ebx` 是两个不同的寄存器,它们存储的值也不相同。所以 `eax` 和 `ebx` 不会相等。但是你可以使用 `eax` 寄存器中的值来读取 `Array` 中的元素。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 FishC 发表于 2024-1-12 12:13
你的问题出在 `mov eax,` 这一行。这里应该将 `Array` 的地址赋值给 `eax` 寄存器,而不是留空。正确的代码 ...
小甲鱼你好:
mov eax, 这条指令是读取压入堆栈的参数
请再仔细看看 lm68140318 发表于 2024-01-12 13:30
小甲鱼你好:
mov eax, 这条指令是读取压入堆栈的 ...
非常抱歉,我之前的回答有误。你是对的,`mov eax,` 指令是用来读取压入堆栈的参数。
在你的代码中,`AddTwo` 过程接受一个参数 `dwParam1`。当你调用 `INVOKE AddTwo, ADDR Array` 时,会将 `Array` 的地址压入堆栈作为参数。
为了在 `AddTwo` 过程中访问 `Array`,你需要使用基址寻址的方式。可以使用以下代码:
AddTwo PROC dwParam1:DWORD
push ebp
mov ebp, esp
add dwParam1, ; 使用基址寻址获取 Array 地址
...
这里使用了 `` 的偏移量来获取 `dwParam1` 参数的值,即 `Array` 的地址。然后,你可以在 `AddTwo` 过程中使用 `dwParam1` 来操作 `Array`。
希望这次解答能够帮到你,如果还有其他问题,请随时提出。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 把你编译好的可执行程序发上来,我帮你看看
页:
[1]