微型计算机原理与应用实验,微型计算机原理与应用实验

  • Post author:
  • Post category:其他


a7f4a3f590493a1e451dd952a488fd7c.gif
微型计算机原理与应用实验

(25页)

6102d6ae6123c5388340a9d4020bec6d.gif

本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦!

23.9 积分

例如,设计一个256分支的段内程序转移程序。  设JUMP单元有一个数X,若X0,则转移到标号为P000的程序段;若X1,则转移到标号为P001的程序段,……;若X255,则转移到标号为P255的程序段。DATA SEGMENT JUMP DB ? ; 某数X TAB DW P000; 分支程序标号 DW P001  …… DW P255  DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATABEG: MOV AX, DATA MOV DS, AX MOV BL, JUMP MOV BH, 0 ADD BX, BX ; 2×X→BX寄存器 MOV SI, OFFSET TAB JMP [BX+SI] ; DS:[BX+SI]→IP实现转移 P000: … … P001: … …… … … … P255: … … CODE ENDS END BEG例4.2 字节型变量VAR1、VAR2和VAR3存放有3个无符号数,将其中的内容按从大到小重新排列。 解:经重新排列后,VAR1的值最大,VAR3的值最 小。由于变量中存放的数据为无符号数,因此应该采用JA、JAE、JB、JBE等指令。编程思路:通过在三个数中找出最大值,将它与VAR1单元进行交换;然后对剩余的两个数进行比较,将较大值存放在VAR2中。汇编语言程序如下:STACK SEGMENT STACK ‘STACK’ DW 100H DUP(?)TOP LABEL WORDSTACK ENDSDATA SEGMENTVAR1 DB 46H ;先假设一组值,以便检验程序设计  的正确性VAR2 DB 15HVAR3 DB 0A2HDATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACKSTART: MOV AX, DATA MOV DS, AX MOV ES, AX MOV AX, STACK MOV SS, AX LEA SP,TOP MOV AL,VAR1 ;用户编写的程序 CMP AL,VAR2 JAE NO_CHG1 XCHG AL,VAR2NO_CHG1: CMP AL,VAR3 JAE NO_CHG2 XCHG AL,VAR3NO_CHG2: MOV VAR1,AL ;最大值保存到VAR1 MOV AL,VAR2 CMP AL,VAR3 JAE NO_CHG3 XCHG AL,VAR3 MOV VAR2,AL ;次大值保存到VAR2NO_CHG3: MOV AH,4CH ;返回DOS操作系统 INT 21HCODE ENDS END START程序执行后,(VAR1)=0A2H,(VAR2)=46H,(VAR3)=15H,说明程序设计正确。一般来说,在程序结束处,应该使之返回到DOS状态,以便进行其它操作。 当要排序的数据为有符号数时,只需要将程序中相应的JAE指令改成JGE指令。 例4.3 有一组测试数据(有符号数),每个数据占用16位二进制数,数据个数存放在缓冲区的前2个字节,现要求分别统计出大于0、等于0和小于0的个数,分别存放在GREATZ、ZERO、LITTLEZ单元中。解:有符号数的比较应该采用JG、JGE、JL、JLE等指令,同时还应该注意,MOV指令不会影响PSW中的标志位。编程思路:将字单元GREATZ、ZERO、LITTLEZ用作为计数器,其初值均为0。然后对数据与“0”比较,当其大于0时,GREATZ单元加1;当其等于0时,ZERO单元加1;当其小于0时,LITTLEZ单元加1。程序如下:STACK SEGMENT STACK ‘STACK’ DW 100H DUP(?)TOP LABEL WORDSTACK ENDSDATA SEGMENTBUFFER DW 500 ;假设有500个数据,并利用重复宏随机 X=17 产生 REPT 500 X=(X+979) mod 65535 DW X ENDMGREATZ DW ?ZERO DW ?LITTLEZ DW ?DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK START: MOV AX, DATA MOV DS, AX MOV ES, AX MOV AX, STACK MOV SS, AX LEA SP,TOP XOR AX,AX ;用户编写的程序 MOV GREATZ,AX MOV ZERO,AX MOV LITTLEZ,AX MOV CX,BUFFER LEA SI,BUFFER+2ST_COUNT: MOV AX,[SI] ADD SI,2 AND AX,AX JLE COUNT1 INC GREATZ JMP COUNT3COUNT1: JL COUNT2 INC ZERO JMP COUNT3 关 键 词: 微型计算机 原理 应用 实验

4d91c43bfc72ca913299809b07b4968f.gif
天天文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。