lm68140318 发表于 2024-1-12 12:12:56

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,可是实际不相等如图

FishC 发表于 2024-1-12 12:13:13

你的问题出在 `mov eax,` 这一行。这里应该将 `Array` 的地址赋值给 `eax` 寄存器,而不是留空。正确的代码应该是这样的:

mov eax, OFFSET Array

这样就能将 `Array` 的地址赋值给 `eax` 寄存器。然后你可以在 `AddTwo` 过程中使用 `eax` 来操作 `Array`。

另外,关于你的疑问,实际上 `eax` 和 `ebx` 是两个不同的寄存器,它们存储的值也不相同。所以 `eax` 和 `ebx` 不会相等。但是你可以使用 `eax` 寄存器中的值来读取 `Array` 中的元素。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

lm68140318 发表于 2024-1-12 13:30:03

FishC 发表于 2024-1-12 12:13
你的问题出在 `mov eax,` 这一行。这里应该将 `Array` 的地址赋值给 `eax` 寄存器,而不是留空。正确的代码 ...

小甲鱼你好:
mov eax,   这条指令是读取压入堆栈的参数
请再仔细看看

FishC 发表于 2024-1-12 13:30:42

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 小助理,如未能正确解答您的问题,请继续追问。

人造人 发表于 2024-1-12 15:16:01

把你编译好的可执行程序发上来,我帮你看看
页: [1]
查看完整版本: addr