• 汇编语言引用参数简介

    引用参数通常是由过程用基址-偏移量寻址(从 EBP)方式进行访问。由于每个引用参数都是一个指针,因此,常常作为一个间接操作数放在寄存器中。例如,假设堆栈地址 [ebp+12] 存放了一个数组指针,则下述语句就把该指针复制到 ESP 中:

    mov esi, [ebp+12 ]   ;指向数组

    【示例】下面将要展示的 ArrayFill 过程用 16 位整数的伪随机序列来填充数组。它接收两个参数:数组指针和数组长度,第一个为引用传递,第二个为值传递。调用示例如下:

    .data
    count = 100
    array WORD count DUP(?)
    
    .code
    main PROC
        push OFFSET array
        push COUNT
        call ArrayFill

    在 ArrayFill 中,下面的代码为其开始部分,对堆栈帧指针(EBP)进行初始化:

    ArrayFill PROC   
        push ebp
        mov ebp,esp

    现在,堆栈帧中包含了数组偏移量、数组长度(count)、返回地址以及被保存的 EBP:

更多...

加载中...