寻找新的一条线

时间:2015-12-13 22:47:25

标签: assembly dos 16-bit real-mode

我是装配新手,我的任务是读取文件的名称并打印此文件中的偶数行。我不知道如何找到新的一行。我知道我必须cmp 13和10,因为这是回车,但我没有成功。任何帮助将不胜感激。这是我到目前为止所做的:

assume cs:code, ds:data
data segment
message1 db 'Name of the file: $'
message2 db 'Even linis: $'
maxFileName db 12
lFileName db ?
fileName db 12 dup (?)
buffer db 8 dup (?), '$'
openErrorMsg db 'Open error!$'
readErrorMsg db 'Read error!$'
data ends

code segment    
start:

    mov ax, data
    mov ds, ax

    ;print initial message
    mov ah, 09h
    mov dx, offset message1
    int 21h

    ;read name of the file
    mov ah, 0ah
    mov dx, offset maxFileName
    int 21h

    ;convert name of the file to ASCIIZ
    mov al, lFileName
    xor ah, ah
    mov si, ax
    mov fileName[si], 0

    ;open file
    mov ah, 3dh
    mov al, 0
    mov dx, offset fileName
    int 21h

    jc openError ;error <=> CF=1
    mov bx, ax

    ;end of line
    mov dl, 10
    mov ah, 02h
    int 21h
    mov dl, 13
    mov ah, 02h
    int 21h

    ;print second message
    mov ah, 09h
    mov dx, offset message2
    int 21h

    ;end of line
    mov dl, 10
    mov ah, 02h
    int 21h
    mov dl, 13
    mov ah, 02h
    int 21h

    read:
        mov ah, 3fh
        mov dx, offset buffer
        mov cx, 8 ;read 8 char
        int 21h
        jc readError ;error <=> CF=1

        cmp buffer, 0Dh
        je read

        ;save bytes number and add $ for printing
        mov si, ax
        mov buffer[si], '$'     

    afisare:
        ;print what have we read
        mov ah, 09h
        int 21h
        cmp si, 8
        je read ;if we read 8 bytes, we have yet to read all

    jmp endPb ;nu exista erori

    openError:
        mov ah, 09h
        mov dx, offset openErrorMsg
        int 21h
        jmp endPb

    readError:
        mov ah, 09h
        mov dx, offset readErrorMsg
        int 21h 

    endPb:
        mov ax,4c00h
        int 21h

    mov ax,4c00h
    int 21h
code ends
end start

1 个答案:

答案 0 :(得分:2)

麻烦在于您的read代码。我添加了评论,让您更容易看到错误:

read:
    mov ah, 3fh              ; Read from file or device
    mov dx, offset buffer    ; Read destination
    mov cx, 8                ; Read 8 characters into buffer
    int 21h                  ; BIOS call
    jc readError             ; Check for error in carry flag

    ;;; vvv Here's your problem
    cmp buffer, 0Dh          ; Check to see if the memory address of
                             ; buffer is 0x0d
    ;;; ^^^ Here's your problem

    je read                  ; If the address is 0x0d, jump back and read again

如上所述,问题在于您将错误的内容与0x0d进行比较。你可能打算这样做:

    cmp [buffer], 0dh

虽然这会比较数据而不是buffer的地址字面值,但它仍然不完整。你真的想要比较读取的每个字节以查看它是否包含ASCII 13.我会把它留给你,因为它是一个家庭作业:)