1

私はアセンブリ言語プログラミングの初心者で
、バイナリ検索プログラムを検索してこれを見つけ、プログラムを理解しようとしました。正常に動作していますが、コードの成功部分を理解できませんでした:

とはADD al,'0'mov res,alですか?

.model small
.stack 100h
.data
    ARR DW 1000H,2000H,3000H,4000H,5000H,6000H
    LEN DW ($-ARR)/2
    KEY EQU 2000H
    SUC DB "KEY IS FOUND AT$"
    FAILURE DB "KEY IS NOT FOUND$"
    RES DB "POSITION",13,10,"$"
.CODE
    START:
        MOV AX,@data
        MOV DS,AX
        MOV BX,00           ;LOW
        MOV DX,LEN          ;HIGH
        MOV CX,KEY          ;KEY
    AGAIN:
        CMP BX,DX
        JA FAIL
        MOV AX,BX
        ADD AX,DX
        SHR AX,1
        MOV SI,AX
        ADD SI,SI
        CMP CX,ARR[SI]
        JAE BIG             
        DEC AX          
        MOV DX,AX
        JMP AGAIN
    BIG:
        JE SUCCESS      
        INC AX          
        MOV BX,AX
    JMP AGAIN
    SUCCESS:
        ADD AL,01
        ADD AL,'0'
        MOV RES,AL
        LEA DX SUC
        JMP DISP
    FAIL:
        LEA DX,FAILURE
    DISP:
        MOV AH,09H
        INT 21H
        MOV AH,4CH
        INT 21H
    END START
4

2 に答える 2

3

add al, '0'成功した場合に結果値として画面に表示するために、1 桁の数字を対応する ASCII コードに変換します。

mov res, alレジスタ AL の値を変数 RES の最初のバイトに格納します。RES が文字列を指している限り'POSITION',13,10,'$'、AL の値はこの文字列の文字「P」の上に格納され、たとえば AL=33h の場合、文字列は になり'3OSITION',13,10,'$'ます。

于 2013-10-23T18:51:50.857 に答える
0
bsearch proc term:DWORD,array:DWORD,asize:DWORD

    mov eax,array
    mov ecx,array
    add ecx,asize
    @@:
    cmp eax,ecx
    jg not_found
    mov edx,eax
    add edx,ecx
    shr edx,1
    xchg DWORD PTR [edx],eax
    cmp eax,term
    xchg DWORD PTR [edx],eax
    jg search_right
    jl search_left
    mov eax,edx
    sub eax,array
    ret
    search_right:
    mov ecx,edx
    jmp @B
    search_left:
    mov eax,edx
    jmp @B
    not_found:
    mov eax,-1
    ret
bsearch endp
于 2014-09-14T10:56:18.080 に答える