《微机原理与接口技术第二版课后习题答案-龚尚福版(共38页).doc》由会员分享,可在线阅读,更多相关《微机原理与接口技术第二版课后习题答案-龚尚福版(共38页).doc(38页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上微机原理与接口技术部分答案第二版主编:龚尚福2.2 8086微处理器由哪几部分组成?各部分的功能是什么?16355 【解】:按功能可分为两部分:总线接口单元BIU(Bus Interface Unit)和执行单元EU(Execution Unit)。总线接口单元BIU是8086 CPU在存储器和I/O设备之间的接口部件,负责对全部引脚的操作,即8086对存储器和I/O设备的所有操作都是由BIU完成的。所有对外部总线的操作都必须有正确的地址和适当的控制信号,BIU中的各部件主要是围绕这个目标设计的。它提供了16位双向数据总线、20位地址总线和若干条控制总线。 其具体任务
2、是:负责从内存单元中预取指令,并将它们送到指令队列缓冲器暂存。CPU执行指令时,总线接口单元要配合执行单元,从指定的内存单元或I/O端口中取出数据传送给执行单元,或者把执行单元的处理结果传送到指定的内存单元或I/O端口中。执行单元EU中包含1个16位的运算器ALU、8个16位的寄存器、1个16位标志寄存器FR、1个运算暂存器和执行单元的控制电路。这个单元进行所有指令的解释和执行,同时管理上述有关的寄存器。EU对指令的执行是从取指令操作码开始的,它从总线接口单元的指令队列缓冲器中每次取一个字节。如果指令队列缓冲器中是空的,那么EU就要等待BIU通过外部总线从存储器中取得指令并送到EU,通过译码电
3、路分析,发出相应控制命令,控制ALU数据总线中数据的流向。2.3 简述8086 CPU的寄存器组织。【解】:(1)通用寄存器:通用寄存器又称数据寄存器,既可作为16位数据寄存器使用,也可作为两个8位数据寄存器使用。当用作16位时,称为AX、BX、CX、DX。当用作8位时,AH、BH、CH、DH存放高字节,AL、BL、CL、DL存放低字节,并且可独立寻址。这样,4个16位寄存器就可当作8个8位寄存器来使用。(2)段寄存器:段寄存器共有4个CS、DS、SS、ES。代码段寄存器CS表示当前使用的指令代码可以从该段寄存器指定的存储器段中取得,相应的偏移值则由IP提供;堆栈段寄存器SS指定当前堆栈的起始
4、地址;数据段寄存器DS指示当前程序使用的数据所存放段的起始地址;附加段寄存器ES则指出当前程序使用附加段地址的起始位置,该段一般用来存放原始数据或运算结果。 (3)指针和变址寄存器:堆栈指针SP用以指出在堆栈段中当前栈顶的地址。入栈(PUSH)和出栈(POP)指令由SP给出栈顶的偏移地址。基址指针BP指出要处理的数据在堆栈段中的基地址,故称为基址指针寄存器。变址寄存器SI和DI用来存放当前数据段中某个单元的偏移量。(4)指令指针与标志寄存器:指令指针IP的功能跟Z80 CPU中的程序计数器PC的功能类似。正常运行时,IP中存放的是BIU要取的下一条指令的偏移地址。它具有自动加1功能,每当执行一
5、次取指令操作时,它将自动加1,使它指向要取的下一内存单元,每取一个字节后IP内容加1,而取一个字后IP内容则加2。某些指令可使IP值改变,某些指令还可使IP值压入堆栈或从堆栈中弹出。标志寄存器FLAGS是16位的寄存器,8086共使用了9个有效位,标志寄存器格式如图2.5所示。其中的6位是状态标志位,3位为控制标志位。状态标志位是当一些指令执行后,表征所产生数据的一些特征。而控制标志位则可以由程序写入,以达到控制处理机状态或程序执行方式的表征。2.4 试述8086 CPU标志寄存器各位的含义与作用。【解】:(1) 6个状态标志位的功能分别叙述如下: CF(Carry Flag)进位标志位。当执
6、行一个加法(或减法)运算,使最高位产生进位(或借位)时,CF为1;否则为0。 PF(Parity Flag)奇偶标志位。该标志位反映运算结果中1的个数是偶数还是奇数。当指令执行结果的低8位中含有偶数个1时,PF=1;否则PF=0。 AF(Auxiliary carry Flag)辅助进位标志位。当执行一个加法(或减法)运算,使结果的低4位向高4位有进位(或借位)时,AF=1;否则AF=0。ZF(Zero Flag)零标志位。若当前的运算结果为零,ZF=1;否则ZF=0。SF(Sign Flag)符号标志位。它和运算结果的最高位相同。OF(Overflow Flag)溢出标志位。当补码运算有溢出
7、时,OF=1;否则OF=0。(2) 3个控制标志位用来控制CPU的操作,由指令进行置位和复位。DF(Direction Flag)方向标志位。它用以指定字符串处理时的方向,当该位置“1”时,字符串以递减顺序处理,即地址以从高到低顺序递减。反之,则以递增顺序处理。IF(Interrupt enable Flag)中断允许标志位。它用来控制8086是否允许接收外部中断请求。若IF=1,8086能响应外部中断,反之则不响应外部中断。注意:IF的状态不影响非屏蔽中断请求(NMI)和CPU内部中断请求。TF(Trap Flag)跟踪标志位。它是为调试程序而设定的陷阱控制位。当该位置“1”时,8086 C
8、PU处于单步状态,此时CPU每执行完一条指令就自动产生一次内部中断。当该位复位后,CPU恢复正常工作。2.5 8086中,存储器为什么采用分段管理? 【解】:8086/8088的地址总线宽度为20位,其最大寻址空间是1MB。而其他微处理器则在实模式下只能访问前1 MB的存储器地址。实际上,实模式就是为8086/8088而设计的工作方式,它要解决在16位字长的机器里怎么提供20位地址的问题,而解决的办法是采用存储器地址分段的方法。程序员在编制程序时要把存储器划分成段,在每个段内地址空间是线性增长的。每个段的大小可达64KB,这样段内地址可以用16位表示。存储器分段的方法虽然给程序设计带来一定的麻
9、烦,但这种方法可以扩大存储空间,而且对于程序的再定位也是很方便的。2.6 什么是逻辑地址?什么是物理地址?如何由逻辑地址计算物理地址?【解】:物理地址:完成存储器单元或I/O端口寻址的实际地址成为物理地址,CPU型号不同其物理地址也不同。物理地址是指CPU和存储器进行数据交换时实际所使用的地址,而逻辑地址是程序使用的地址。物理地址由两部分组成:段基址(段起始地址高16位)和偏移地址。前者由段寄存器给出,后者是指存储单元所在的位置离段起始地址的偏移距离。当CPU寻址某个存储单元时,先将段寄存器的内容左移4位,然后加上指令中提供的16位偏移地址而形成20位物理地址。在取指令时,CPU自动选择代码段
10、寄存器CS,左移4位后,加上指令提供的16位偏移地址,计算出要取指令的物理地址。堆栈操作时,CPU自动选择堆栈段寄存器SS,将其内容左移4位后,加上指令提供的16位偏移地址,计算出栈顶单元的物理地址。每当存取操作数时,CPU会自动选择数据段寄存器(或附加段寄存器ES),将段基值左移4位后加上16位偏移地址,得到操作数在内存的物理地址。2.9 在80x86微机的输入/输出指令中,I/O端号通常是由DX寄存器提供的,但有时也可以在指令中直接指定00H0FFH的端口号。试问可直接由指令指定的I/O端口数是多少?【解】:由于在80x86的输入/输出指令中,可以直接在00H0FFH指定,所以直接由指令指
11、定的I/O端口数是256。3.1 指令分成几部分?每部分的作用是什么?【解】:每条指令由两部分组成:操作码字段和地址码字段。操作码字段:用来说明该指令所要完成的操作。 地址码字段:用来描述该指令的操作对象。一般是直接给出操作数,或者给出操作数存放的寄存器编号,或者给出操作数存放的存储单元的地址或有关地址的信息。3.2 指出下列MOV指令的源操作数的寻址方式:MOVAX,1234HMOVAX,BXMOVAX,BXMOVAX,TABLE;TABLE ;TABLE是一个变量名MOVAX,1234HMOVAX,BX+1234HMOVAX,BPSIMOVAX,BX+SI-1234H【解】:MOVAX,1
12、234H 立即寻址MOVAX,BX 寄存器寻址MOVAX,BX 寄存器间接寻址MOVAX,TABLE ;TABLE是一个变量名 直接寻址方式MOVAX,1234H 直接寻址方式MOVAX,BX+1234H 寄存器相对寻址MOVAX,BPSI 基址变址寻址MOVAX,BX+SI1234H 相对地址变址寻址3.3 设:(DS)=2000H,(BX)=0100H,(SS)=1000H,(BP)=0010H,TABLE的物理地址为2000AH,(SI)=0002H。求下列每条指令源操作数的存储单元地址:MOVAX,1234HMOVAX,BXMOVAX,TABLEBXMOVAX,BPMOVAX,BPSI
13、【解】: 存储单元地址:(DS)10H + EA =2000H10H+1234H=21234H存储单元地址:(DS)10H +(BX)=2000H10H+0100H=20100H存储单元地址:(DS)10H+EA=2000H10H+0100H+000AH=2010AH存储单元地址:(SS)10H+EA=1000H10H+0010H=10010H储单元地址:(SS)10H+EA=1000H10H+0010H+0002H =10012H3.4 设ARRAY是字数组的首地址,写出将第5个字元素取出送AX寄存器的指令,要求使用以下几种寻址方式: 直接寻址 寄存器间接寻址 寄存器相对寻址 基址变址寻址【
14、解】:(1)直接寻址(2)寄存器间接寻址(3)寄存器相对寻址(4)基址变址寻址 MOV AX, ARRAY+8 MOV BX, ARRAY+8 MOV BX, 8 LEA BX, ARRAY MOV AX, BX MOV AX, ARRAYBX MOV SI, 8 MOV AX,BX+SI3.5 设当前(CS)=2000H,(IP)=2000H,标号NEXT定义在当前代码段偏移地址是0100H处,(DS)=1000H,(BX)=1000H,(11000H)=00H,(11001H)=30H,数据段定义的字变量ARRAY的内容为1000H,试写出下列转移指令的目标转移地址 JMPNEARPTR
15、JMPBX JMPWORDPTRARRAY【解】: JMPNEARPTR 此转移指令的目标转移地址为:20100H JMPBX 此转移指令的目标转移地址为:21000H JMPWORDPTRARRAY 此转移指令的目标转移地址为:23000H3.6 设当前(CS)=2000H,(IP)=2000H,标号NEXT定义在3000H:1000H处。当前(DS)=1000H,(BX)=1000H,(11000H)=00H,(11001H)=03H,(11002H)=00H,(11003H)=30H,数据段定义的字变量ARRAY的内容为0300H,(ARRAY+2)=3000H,试写出下列转移指令的目标
16、转移地址: JMPFARPTRNEXT JMPDWORDARRAY【解】: JMPFARPTRNEXT 此转移指令的目标转移地址为:31000H JMPDWORDARRAY 此转移指令的目标转移地址为:30300H3.7 下列每组指令有何区别?(1)MOV AX,1234H MOV AX,1234H (2)MOV AX,TABLEMOV AX,TABLE(3)MOV AX,TABLE LEAAX,TALBE(4)MOV AX,BX MOV AX,BX【解】:(1)MOV AX,1234H 将立即数1234H送到寄存器AX中 MOV AX,1234H 将存储区1234H中的内容送到寄存器AX中(
17、2)MOV AX,TABLE 将标号TABLE的地址送到寄存器AX中MOV AX,TABLE 将存储区TABLE 中的内容送到寄存器AX中(3)MOV AX,TABLE 将标号TABLE的地址送到寄存器AX中 LEA AX,TALBE 将标号TABLE的地址送到寄存器AX中(4)MOV AX,BX 寄存器寻址 MOV AX,BX 寄存器间接寻址3.8 MOVCS,AX指令正确吗?【解】:MOVCS,AX指令不正确。因为CS是指令寄存器,由系统自动改变,不能由指令进行更改。3.9 写一指令序列,将3456H装入DS寄存器。【解】:MOV AX, 3456H MOV DS, AX3.10 若正在访
18、问堆栈中03600H单元,则SS和SP的值是多少?【解】:若正在访问堆栈中03600H单元,则SS和SP的值会有好多组合,其中可以有SS是0300H,SP是0600H。3.11 若(SS)=2000H,(SP)=000AH,先执行将字数据1234H和5678H压入堆栈的操作,再执行弹出一个字数据的操作,试画出堆栈区及SP的内容变化过程示意图(标出存储单元的物理地址)。SP20006H78H【解】:物理地址(SS)10HSP 20007H56H34HSP20008H 20008H 20009H 2000AH12H34H12H 20009HSP2000AH 2000AH3.16 解释XLAT指令是
19、怎样转换AL寄存器中的内容的。并编写一段程序用XLAT指令将BCD码09转换成对应的ASCII码,并将ASCII码存入数据ARRAY中。【解】:XLAT指令是将AL的内容替换成存储单元中的一个数,往往用于代码转换。使用此指令前,先在数据段建立一个表格,表格首地址存入BX寄存器,欲取代码的表内位移量存入AL寄存器中。XLAT指令将(AL)值扩展成16位,与(BX)相加形成一个段偏移地址,段地址取(DS),据此读出代码送入AL寄存器。程序如下:TABLE DB 30H, 31H, , 39H ARRAY DB 1O DUP(?) MOV CL, 10 MOV SI, 0 MOV BX, OFFSE
20、T TABLE MOV AL, AL AGAIN: XLAT MOV SI, AL INC SI INC AL LOOP AGAIN3.17 若(AX)=0001H,(BX)=0FFFFH,执行ADD AX,BX之后,标志位ZF、SF、CF和OF各是什么?【解】: (AX)= 0001H = 0000 0000 0000 0001 B + (BX)=0FFFFH = 1111 1111 1111 1111 B (AX)= 0001H = 1 0000 0000 0000 0000 B 则:ZF=1、SF=0、CF=1、OF=03.18 写一指令序列完成将AX寄存器的最低4位置1,最高3位清0,
21、第7、8、9位取反,其余位不变。【解】: OR AX, 000FH (OR AX, 0000 0000 0000 1111 B) AND AX, 1FFFH (AND AX, 0001 1111 1111 1111 B) XOR AX, 01C0H (XOR AX, 0000 0001 1100 0000 B)3.19 试写出执行下列指令序列后AX寄存器的内容。执行 前(AX)=1234H。MOV CL,7SHL BX,CL【解】:(AX) = 1234H = 0001 0010 0011 0100 B 执行后:(AX) = 0 0011 0100 0000 000 B = 0001 1010
22、 0000 0000 B = 1A00H 4.1 假设下列指令中的所有标识符均为类型属性为字的变量,请指出下列指令中哪些是非法的?它们的错误是什么? MOV BP,AL MOV WORD_OPBX+4*3DI,SP MOV WORD_OP1,WORD_OP2 MOV AX,WORD_OP1DX MOV SAVE WORD,DS MOV SP,SS:DATA_WORDBXSI MOV BXSI,2 MOV AX,WORD_OP1+WORD_OP2 MOV AX,WORD_OP1-WORD_OP2+100 MOV WORD_OP1,WORD_OP1-WORD_OP2【解】: MOV BP,AL 两
23、个操作数不匹配 MOV WORD_OPBX+4*3DI,SP MOV WORD_OP1,WORD_OP2两个内存单元之间不能直接传送数据 MOV AX,WORD_OP1DX MOV SAVE WORD,DS MOV SP,SS:DATA_WORDBXSI当基址为BX时,选取DS寄存器 MOV BXSI,2 MOV AX,WORD_OP1+WORD_OP2 MOV AX,WORD_OP1-WORD_OP2+100 MOV WORD_OP1,WORD_OP1-WORD_OP24.2 假设VAR1和VAR2为字变量,LAB为标号,试指出下列指令的错误之处: ADD VAR1,VAR2 SUB AL,
24、VAR1 JMP LABSI JNZ VAR1 JMP NEAR LAB【解】: ADD VAR1,VAR2ADD两个操作数不能同时为存储单元,MOV AX, VAR1 ADD AX, VAR2 SUB AL,VAR1两个操作数不匹配SUB AX, VAR1 JMP LABSI LAB与SI不能相加JMP WORD PTR SI JNZ VAR1JNZ后面应是标号,不应是变量JNZ LAB JMP NEAR LAB缺少PTR运算符JMP NEAR PTR LAB4.3 画图说明下列语句所分配的存储空间及初始化的数据值。 BYTE_VAR DB BYTE,12,-12H,3 DUP(0,?,2
25、DUP(1,2),?) WORD_VAR DW 5 DUP(0,1,2),?,-5,BY,TE,256HWORD_VAR00H00H01H00H02H00H00H00H01H00H02H00HBBYTE_VAR41H【解】:(1) (2) 0Y59H1E45HT54H120CH212HF4H30个字节00H0210101H02H2101H200H0202H101H202H101H02H2FBH5FFH54H00H56H00H45HBYTE00H41H59H00H02H101H000H202H101H2256H02H4.4 假设程序中的数据定义如下:PARTNO DW ?PNAME DB 16
26、DUP(?)COUNT DD ?PLENTH EQU $-PARTNO问PLENTH的值为多少?它表示什么意义?【解】:PLENTH的值为22,它表示数据的个数。4.5 有符号定义语句如下:BUFF DB 1,2,3,123EBUFF DB 0L EQU EBUFF-BUFF问L的值是多少?【解】:PLENTH的值为6。4.6 假设程序中的数据定义如下:LNAME DB 30 DUP(?)ADDRESS DB 30 DUP(?)CITY DB 15 DUP(?)CODE-LIST DB 1,7,8,3,2 用一条MOV指令将LNAME的偏移地址放入AX。 用一条指令将CODE_LIST的头两个
27、字节的内容放入SI。 写一条伪操作使CODE_LENGHT的值等于CODE_LIST域的实际长度。【解】: 用一条MOV指令将LNAME的偏移地址放入AX。 MOV AX, OFFSET LANME 用一条指令将CODE_LIST的头两个字节的内容放入SI。MOV SI, WORD PTR CODE_LSIT 写一条伪操作使CODE_LENGHT的值等于CODE_LIST域的实际长度。 CODE_LENGHT EQU CITY-CODE_LIST4.7 试写出一个完整的数据段DATA_SEG,它把整数5赋予一个字节,并把整数-1,0,2,5和4放在10字数组DATA_LIST的头5个单元中。然
28、后,写出完整的代码段,其功能为:把DATA_LIST中头5个数中的最大值和最小值分别存入MAX和MIN单元中。【解】:参考程序如下: DATA_SEG SEGMENT DB1 DB 5 DATA_LIST DB -1, 0, 2, 5, 4, 5 DUP(?) COUNT DB 5 MAX DB ? MIN DB ? DATA_SEG ENDS CODE_SEG SEGMENT ASSUME CS:CODE_SEG, DS:DATA_SEG START PROC FAR PUSH DS MOV AX, 0 PUSH AX MOV AX, DATA_SEG MOV DS, AX LEA BX,
29、DATA_LIST MOV CX, COUNT-1 MOV AL, BX MOV AH, BX+1 LOOP1: INC BX CMP AH, AL JAE LOOP1 XCHG AH, AL LOOP2 INC BX CMP AH, BX JAE LIS XCHG AH, BX JMP LOP2 LIS: CMP AL , BX JBE LOP2 XCHG AL, BX LOOP2 MOV MAX, AH MOV MIN, AL RET START ENDP CODE_SEG ENDS END START4.10 给出等值语句如下:ALPHAEQU100BETAEQU25GAMMAEQU2下
30、列表达式的值是多少? ALPHA*100+BETA ALPHAMODGAMMA+BETA (ALPHA+2)*BETA-2 (BETA/3)MOD 5 (ALPHA+3)*(BETA MOD GAMMA) ALPHA GE GAMMA BETA AND 7 GAMMA OR 3【解】: ALPHA*100+BETA1001002510025 ALPHAMODGAMMA+BETA100/(252)19 (ALPHA+2)*BETA-2 (100+2)*252548 (BETA/3)MOD 5(25/3) MOD 53 (ALPHA+3)*(BETA MOD GAMMA) (100+3)*(25
31、MOD 2)103 ALPHA GE GAMMA 100 GZ GAMMA0FFFFH BETA AND 725 AND 71 GAMMA OR 32 OR 334.9 对于下面的数据定义,三条MOV指令分别汇编成什么?(可用立即数方式表示)TABLEADW10 DUP(?)TABLEBDB10 DUP(?)TABLECDB1234 MOVAX,LENGTH TABLEAMOVBL,LENGTH TABLEBMOVCL,LENGTH TABLEC【解】:MOVAX,LENGTH TABLEAMOV AX, OOOAHMOVBL,LENGTH TABLEB MOV BL, 0AHMOVCL,LE
32、NGTH TABLEC MOV CL, O1H4.10 对于下面的数据定义,各条MOV指令单独执行后,有关寄存器的内容是什么?FLDBDB?TABLEADW20DUP(?)TABLEBDBABCD MOV AX,TYPE FLDB MOV AX,TYPE TABLEA MOV CX,LENGTH TABLEA MOV DX,SIZE TABLEA MOV CX,LENGTH TABLEB【解】:(1) MOV AX,TYPE FLDB (AX)= 1 (2) MOV AX,TYPE TABLEA (AX)= 2 (3) MOV CX,LENGTH TABLEA (CX)= 20 (4) MOV
33、 DX,SIZE TABLEA (DX)= 40 (5) MOV CX,LENGTH TABLEB (CX)= 1 8.1 解释下列概念: 中断DMA,中断源,中断向量中断向量表,不可屏蔽中断,通道FCB,中断嵌套,文件标记中断入口,可屏蔽中断【解】:答: 当进程要求设备输入数据时,CPU把准备存放输入数据的内存起始地址以及要传送的字节数分别送入DMA控制器中的内存地址寄存器和传送字节计数器。 发出数据传输要求的进行进入等待状态。此时正在执行的CPU指令被暂时挂起。进程调度程序调度其他进程占据CPU。 输入设备不断地窃取CPU工作周期,将数据缓冲寄存器中的数据源源不断地写入内存,直到所要求的字
34、节全部传送完毕。 DMA控制器在传送完所有字节时,通过中断请求线发出中断信号。CPU在接收到中断信号后,转入中断处理程序进行后续处理。 中断处理结束后,CPU返回到被中断的进程中,或切换到新的进程上下文环境中,继续执行。中断源:引起中断的事件称为中断源。中断向量表:每种中断都给安排一个中断类型号。80x86中断系统能处理256种类型的中断,类型号为0H0FFH。如图8.3所示的中断源,系统时钟的中断类型为08,键盘为09,软中断中的除法错误的中断类型为0等。每种类型的中断都由相应的中断处理程序来处理,中断向量表就是各类型中断处理程序的入口地址表。中断嵌套:正在运行的中断处理程序,又被其他中断源
35、中断,这种情况叫做中断嵌套。中断就是CPU在执行当前程序时由于内外部事件引起CPU暂时停止当前正在执行的程序而转向执行请求CPU暂时停止的内外部事件的服务程序,该程序处理完后又返回继续执行被停止的程序;中断向量是中断处理子程序的入口地址;地址范围是00000H-003FFH。实验一 系统认识实验一实验目的掌握TDN86/88教学实验系统的基本操作。二实验设备TDN86/88教学实验系统一台。三实验内容及步骤1. 系统认识实验(1)(1)程序的输入与修改从3500H内存单元开始建立0-15共16个数据。实验步骤:a 使用串行通讯电缆将实验系统与PC机相连。b 开启实验系统。c 在系统软件所在目录
36、(默认为C:TANGDUW8688)下运行文件WMD86.EXE进入集成操作软件环境,打开文件菜单选择新建,即可开始输入源程序。d 输入程序后,在文件菜单中选择保存程序,注意文件名的格式,扩展文件名必须为*.ASM,例:ABC.ASM。e 在编译菜单中选择汇编(CTRL+F2)对源程序进行汇编,若源程序没有错误生成目标文件*.OBJ,若源程序中有错误则返回错误信息,根据错误信息对源程序进行修改后再进行汇编。f 汇编无误后,在编译菜单中选择链接(CTRL+F3)对汇编生成的*.OBJ目标文件进行链接,链接信息显示于屏幕上,如没有错误,生成相应的可执行文件*.EXE。g 在窗口菜单中选择调试(CT
37、RL+1)打开调试窗口,出现系统提示符“”后选择菜单中的装入程序,选择相应的*.EXE文件,填入程序段地址与偏移量(默认段地址0000,偏移量2000,一般不用修改),确定后PC开始将程序从磁盘装入到教学实验系统内存,提示装载完毕后使用U命令进行反汇编,检查程序是否正确装入。U命令输入格式为U0000:2000。h 当发现源程序输入错误或需要调整时,在调试窗口下可用A命令来修改,如修改2000句为MOV DI,3500的操作如下:显示信息键入信息A20000000:2000MOV DI,35000000:2003(2)运行程序系统提供了单步运行、断点运行、连续运行等方式,具体操作如下:a. 单
38、步运行:在“”提示符下输入T或点击菜单中的单步运行执行,每运行一条指令后会显示下一条待执行指令并显示变化寄存器的内容,重复T可一步一步运行直至程序结束。b. 连续运行:在“”提示符下输入G0000:2000(在系统默认段址CS0000情况下可直接输入G2000)可连续运行程序,在运行过程中,可通过CTRL+BREAK或点击菜单中的停止来终止程序运行。c. 断点运行:在程序中可用B命令定义断点,系统规定最多定义10个断点,例如:显示信息键入信息B0:20091:上例中定义了2009地址为断点,输入GB0000:2000程序连续运行至断点时,程序中断并显示当前各寄存器内容。GB是G命令的扩充,表示含断点连续运行程序,断点仅当系统复位时清除。(3)内存单元的内容显示:使用D0000:3500可查看3500H-350FH单元中的内容是否为0-15共16个数。(4)内存单元内容的修改:若要修改某一单元内容,可进行如下操作,其中,“空格”键用于向待编辑单元的高地址方向移动地址,而“-”键则向反方向移动地址;用来确认输入,退出E命令。显示信息键入信息E35000000:3500 00_01 space0000:3501 01_Space0000:3502 02_ - 0000:3501 01_2. 系统操作练习(2