【proteus】8086 写一个汇编程序并调试

参考书籍:微机原理与接口技术------基于8086和Proteus仿真(第3版)p103-105,p119-122.

参考程序是p70,例4-1

在上一篇的基础上:

创建项目和汇编文件

写一个汇编程序并编译

双击8086的元件图:

可以修改size

比如这里修改成:

在asm中写一个简单的汇编程序:

复制代码
DATA  SEGMENT		;定义数据段
    X  DW  2010H     	;定义被加数
    Y  DW  2011H	;定义加数
    RESULT  DW   ? ;分配和数存放单元;数据段定义结束
DATA  ENDS       
CODE  SEGMENT
ASSUME      CS:CODE,DS:DATA  
    START:
            MOV   AX,DATA 
            MOV   DS,AX
            MOV  AX,X
            ADD  AX,Y
            MOV  RESULT,AX
	    JMP $
CODE  ENDS
    END  START

编译:

编译通过:

调试:

选中内存和寄存器窗口(第一个和第二个):

F11单步调试:

发现上述代码进入调试状态后会变成这样:

停止调试,把CODE段写在前面(注意end start仍然写在最后):

复制代码
CODE  SEGMENT
ASSUME      CS:CODE,DS:DATA  
    START:
            MOV   AX,DATA 
            MOV   DS,AX
            MOV  AX,X
            ADD  AX,Y
            MOV  RESULT,AX
	    JMP $
CODE  ENDS
DATA  SEGMENT		;定义数据段
    X  DW  2010H     	;定义被加数
    Y  DW  2011H	;定义加数
    RESULT  DW   ? ;分配和数存放单元;数据段定义结束
DATA  ENDS  
    END  START

进入 调试:

第二个按钮也可以实现单步调试:

单击一次该按钮后观察寄存器和内存:

观察到内存发现数据段的首地址是0020,而AX被赋值为0002。(因为地址=段首址*10H+偏移地址,偏移地址由于是从0000开始,所以是正确的)

继续单击:

此时执行到这条语句:

先看一下result的内存内容(图的右侧),发现我们用?预留的空间并不是我们预料的是个随机数,而是00 00

继续调试:

可看出:低字节送入低地址,高字节送入高地址

jmp 构成无条件循环,可以保证仿真持续进行。表示当前地址。

设置断点

双击某一行左侧:

重新进入调试状态点击第一个按钮:

程序在断点处停止:

相关推荐
real_ben_ladeng1 小时前
程序人生—Hello’s P2P 2dc736403375808d93f9c97fc816f2f8
c语言·汇编·硬件架构
开开心心就好4 小时前
实用PDF擦除隐藏信息工具,空白处理需留意
运维·服务器·windows·pdf·迭代器模式·桥接模式·1024程序员节
切糕师学AI5 小时前
ARM标准汇编(armasm)中的“定义”(Assembler Directive)
汇编·arm开发
切糕师学AI6 小时前
ARM标准汇编(armasm)中的标号(Label)
汇编·arm
CHANG_THE_WORLD1 天前
字符串定义的汇编分析
汇编·数据库
CHANG_THE_WORLD1 天前
深入理解C语言指针:从源码到汇编的彻底剖析
c语言·开发语言·汇编
unable code1 天前
浏览器取证-[GKCTF 2021]FireFox Forensics
网络安全·ctf·misc·1024程序员节·浏览器取证
xutSwIpZotzM1 天前
Matlab Simulink 实现事件触发控制仿真并达稳定
proteus
unable code1 天前
内存取证-[安洵杯 2019]Attack
网络安全·ctf·misc·1024程序员节·内存取证
unable code2 天前
CTF-SPCS-Forensics
网络安全·ctf·misc·1024程序员节·取证