当然,上面这段程式并不成立,因为没有出口,永远做不完。程式的终止有很多方法,一是用计数器,一是用位置来比较,也有用终止指令的,不一而足,各有长短。
首先,假设在DS:SI 中,有一长度值,兹以计数器的回路来试试看:
1: LODSW
2: MOV CX,AX ;似此,3B 18C
;若用 MOV CX,[SI]
; INC SI
; INC SI
;则需 6B,21T
3: SUB AL,AL ;先设最小值,备用
4: COMPAR:
5: MOV AH,AL ;设AH为低位值
6: COMPAR1:
7: LODSB ;取资料
8: CMP AL,AH ;比大、小
9: JB COMPAR2 ;低位大,需排序
10: LOOP COMPAR ;回路
11: RET ;完成
12: COMPAR2:
13: MOV [SI-2],AX ;交换AH,AL,排序
14: DEC SI ;向低位再查
15: MOV AH,[SI-2]
16: JMP COMPAR1
程式中的回路,对前面有一比较分支不太有利,因为回路每次要17T ,比较分支就是现成的回路,不利用形成浪费。
若把回路改为位置比较,