0

我正在尝试在程序集 8086 上构建一个针对计算机的井字游戏,但是每当我运行它时,TD 都会卡在这个特定的命令上:

移动 dx, 0

此命令在一个函数中(第三行):

reboard proc
        mov al, 0
        mov bx, 0
        mov dx, 0
        mov cx, bp
        rowdata:
            cmp arr[bx], 'X'
            je rowX
            cmp arr[bx], 'y'
            je rowY
            jmp rowQm
            rowX:
                add al, 100
                jmp rowQm
            rowY:
                add al, 1
            rowQm:
                inc bx
        loop rowdata

        mov cx, bp
        add si, dx
        mov arr[si + 3], al
        sub si, dx
        mov al, 0
        inc dx
        cmp dx, bp
        jnz rowdata

        mov dx, 0
        mov bx, dx
        coldata:
            cmp arr[bx], 'X'
            je colX
            cmp arr[bx], 'Y'
            je colY
            jmp colQm
            colX:
                add al, 100
                jmp colQm
            colY:
                add al, 1
            colQm:
                add bx, bp
                loop coldata
        add si, bp
        add si, dx
        mov arr[si + 3], al
        sub si , dx
        sub si, bp
        inc dx
        mov bx, dx
        mov al, 0
        mov cx, bp
        dec cx
        cmp dx, bp
        jnz coldata
        ret
    reboard endp

此外,函数中的前两个命令被应用,但不对寄存器进行任何更改。

这不是我第一次遇到这个问题,它也发生在另一个函数中(在同一个程序中),同样 - 函数中的前两个命令不起作用。命令是:

电影 dl, 13

我试图将光标向下移动一行。

我还在一个新程序上运行了这个特定的功能,它从头到尾都运行良好,我一无所知,无论如何这是我尝试的新程序:

注意:'X' 的值为 88,'Y' 的值为 89。

dseg segment
    arr db 63, 63, 89, 88, 89, 63, 63, 88, 89
dseg ends
cseg segment
assume cs:cseg, ds:dseg
a proc
    mov al, 0
    mov bx, 0
    mov dx, 0
    mov cx, bp
    rowdata:
        cmp arr[bx], 'X'
        je rowX
        cmp arr[bx], 'Y'
        je rowY
        jmp rowQm
        rowX:
            add al, 100
            jmp rowQm
        rowY:
            add al, 1
        rowQm:
            inc bx
    loop rowdata

    mov cx, bp
    add si, dx
    mov arr[si + 3], al
    sub si, dx
    mov al, 0
    inc dx
    cmp dx, bp
    jnz rowdata

    mov dx, 0
    mov bx, dx
    coldata:
        cmp arr[bx], 'X'
        je colX
        cmp arr[bx], 'Y'
        je colY
        jmp colQm
        colX:
            add al, 100
            jmp colQm
        colY:
            add al, 1
        colQm:
            add bx, bp
            loop coldata
    add si, bp
    add si, dx
    mov arr[si + 3], al
    sub si , dx
    sub si, bp
    inc dx
    mov bx, dx
    mov al, 0
    mov cx, bp
    cmp dx, bp
    jnz coldata
    ret
a endp
Begin:
    mov ax, dseg
    mov ds, ax
    mov bp, 3
    mov si, 9
    call a
    int 3h
cseg ends
end begin

有任何想法吗?

4

1 回答 1

0

我想到了:

TD被冻结的原因是我调用函数的位置离函数本身很远。

我只是将函数复制到更近的位置(在代码中)到我称之为它的地方。这也是当我在一个新程序上运行该函数时,该函数从头到尾完美运行的原因,在另一个程序中,该函数与我调用该函数的位置之间没有太大的空间差异。

于 2013-07-09T09:27:18.100 回答