实验3 转移指令跳转原理及其简单应用编程
2021/11/28 11:10:11
本文主要是介绍实验3 转移指令跳转原理及其简单应用编程,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
实验任务1:
assume cs:code, ds:data data segment x db 1, 9, 3 len1 equ $ - x y dw 1, 9, 3 len2 equ $ - y data ends code segment start: mov ax, data mov ds, ax mov si, offset x mov cx, len1 mov ah, 2 s1:mov dl, [si] or dl, 30h int 21h mov dl, ' ' int 21h inc si loop s1 mov ah, 2 mov dl, 0ah int 21h mov si, offset y mov cx, len2/2 mov ah, 2 s2:mov dx, [si] or dl, 30h int 21h mov dl, ' ' int 21h add si, 2 loop s2 mov ah, 4ch int 21h code ends end start
① line27, 汇编指令 loop s1 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s1其后指令的偏移地址的。
根据反汇编,可以看到loop指令的机器码是“E2F2”,而F2就是位移量的补码形式,转化为十进制就是-14,即跳转的位移量。
loop指令的下一条指令的偏移地址为001B,加上跳转的位移量,即001B-E=000D,刚好是标号S1指令的偏移地址。
② line44,汇编指令 loop s2 跳转时,是根据位移量跳转的。通过debug反汇编,查看其机器码,分析其跳转的位移量是多少?(位移量数值以十进制数值回答)从CPU的角度,说明是如何计算得到跳转后标号s2其后指令的偏移地址的。
根据反汇编,可以看到loop机器码为“E2F0”,而F0就是位移量的补码形式,转化为十进制就是-16,即跳转的位移量。
loop指令的下一条指令的偏移地址为0039,加上跳转的位移量,即0039-0010=0029,刚好是标号S2指令的偏移地址。
实验任务2:
assume cs:code, ds:data data segment dw 200h, 0h, 230h, 0h data ends stack segment db 16 dup(0) stack ends code segment start: mov ax, data mov ds, ax mov word ptr ds:[0], offset s1 mov word ptr ds:[2], offset s2 mov ds:[4], cs mov ax, stack mov ss, ax mov sp, 16 call word ptr ds:[0] s1: pop ax call dword ptr ds:[2] s2: pop bx pop cx mov ah, 4ch int 21h code ends end start
① 根据call指令的跳转原理,先从理论上分析,程序执行到退出(line31)之前,寄存器(ax) = ? 寄存器(bx) = ? 寄存器(cx) = ?
第一条call指令将其之后的指令s1的偏移量入栈,并且跳转执行s1的代码,将栈顶字节出栈并赋给ax,ax也就是s1标记地址的偏移量
第二条call指令将当前代码段的段地址cs和下一条指令s2的偏移地址相继入栈,然后跳转执行s2的代码,先将s2的偏移地址赋给bx,然后将段地址cs赋值给cx,所以bx为s2标记的偏移地址,cx为cs的段地址
② 对源程序进行汇编、链接,得到可执行程序task2.exe。使用debug调试,观察、验证调试结果与理论分析结果是否一致。
可以看到一开始,标记s1的偏移地址为0021,标记s2的段地址为076c,偏移地址为0026
执行完之后,可以看到ax=0021,bx=0026,cx=076c
实验任务3:
assume cs:code, ds:data data segment x db 99, 72, 85, 63, 89, 97, 55 len equ $- x data ends code segment start: mov ax, data mov ds, ax mov si, 0 mov cx, len s: mov ah, 0 mov al, [si] inc si call printNumber call printSpace loop s mov ah, 4ch int 21h printNumber: mov bl, 10 div bl mov bx, ax mov ah, 2 add bl, 48 mov dl, bl ; int 21h add bh, 48 mov dl, bh ; int 21h ret printSpace: mov ah, 2 mov dl,' ' ; int 21h ret code ends end start
实验结果如下:
实验任务4:
assume cs:code, ds:data data segment str db 'try' len equ $ - str data ends stack segment db 16 dup(0) stack ends code segment start: mov ax, data mov ds, ax mov ax,0b800h mov es,ax mov si,offset str mov cx,len mov bl,2 mov bh,0 call printStr mov si,offset str mov cx,len mov bl,4 mov bh,24 call printStr mov ah, 4ch int 21h printStr: mov al,bh push bx mov bl,160 mul bl mov di,ax pop bx s:mov al,[si] mov es:[di],al mov es:[di+1],bl inc si add di,2 loop s ret code ends end start
实验结果如下:
实验任务5:
assume cs:code, ds:data data segment stu_no db '201983290169' len = $ - stu_no data ends code segment start: mov ax, data mov ds, ax mov ax, 0b800h mov es, ax mov si, 1 mov cx, 7d0h ; s: mov byte ptr es:[si],17h ; add si, 2 loop s mov si, 0f00h mov cx, 80 s1: mov byte ptr es:[si], 2dh ; add si, 2 loop s1 mov si, 0f44h ; mov cx, 12 mov bx, 0 s2: mov al, [bx] mov es:[si], al add si, 2 inc bx loop s2 mov ax, 4c00h int 21h code ends end start
实验结果如下:
这篇关于实验3 转移指令跳转原理及其简单应用编程的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-26消息中间件源码剖析教程
- 2024-11-26JAVA语音识别项目资料的收集与应用
- 2024-11-26Java语音识别项目资料:入门级教程与实战指南
- 2024-11-26SpringAI:Java 开发的智能新利器
- 2024-11-26Java云原生资料:新手入门教程与实战指南
- 2024-11-26JAVA云原生资料入门教程
- 2024-11-26Mybatis官方生成器资料详解与应用教程
- 2024-11-26Mybatis一级缓存资料详解与实战教程
- 2024-11-26Mybatis一级缓存资料详解:新手快速入门
- 2024-11-26SpringBoot3+JDK17搭建后端资料详尽教程