汇编语言:简单的16位二进制相加程序

这可以说是第一个我自己写的汇编程序,虽然很短。。
功能很简单,实现两个16位二进制数相加即可。

step 1.写汇编代码

下面是实现功能的相应代码:

DSEG	SEGMENT
DATA_1	DW	?
DATA_2	DW	?
DSEG	ENDS
SSEG	SEGMENT	STACK
TOP_PTR	DB	20 DUP(0)
SSEG	ENDS
CSEG	SEGMENT
	ASSUME	DS : DSEG, SS : SSEG, CS : CSEG
BEG_:	MOV	AX, DSEG
	MOV	DS, AX
	MOV	AX, SSEG
	MOV	SS, AX
	MOV	SP, LENGTH TOP_PTR
	MOV	DATA_1, 0A1A1H
	MOV	DATA_2, 1A1AH
	MOV	AX, WORD PTR DATA_1
	ADD	AX, WORD PTR DATA_2	;FINAL ANSWER IN 'AX' REGISTER
	MOV	AH, 4CH
	INT	21H
CSEG	ENDS
	END 	BEG_

可以看到汇编代码和高级语言比起来确实是要冗长不少的,甚至会让人觉得有一点刻板。但是这也正是它得优点和魅力所在,这些特点也恰巧表明了汇编的高度严格,严谨,要编写好的汇编程序需要我们提前合理的编排程序,进行总体规划,方能实现复杂的功能。

step 2.汇编+链接+debug下运行

1.汇编+链接。
1
因为我的电脑是64位,无法直接运行。所以我下载了DOSBox来在d盘建立虚拟盘符。
2.debug下运行
2
进入Debug模式,输入命令U 0即可从将机器代码反汇编后从CS代码段偏移量为0的地方开始显示汇编代码,以供我们进行操作。
3.运算
从代码中就可以看到我们这里进行A1A1+1A1A的加法运行并将结果保存在AX寄存器中。
3
可以看到A1A1已被送到AX中,下面进行加法。
4
可以看到运算结果BBBB已被存到AX通用寄存器中。

再来看标志寄存器:
第一个状态为NV表示进行的这一次计算没有发生溢出,结果可以被我们正常使用。
第二、三个状态是方向标志和中断标志状态,这里不做讨论。
第四个标志位是NG,表示最高位为1。
第五个标志位是NZ,表示运算结果不为零。
第六个状态位是NA,表示没有发生低四位向高四位的进位。
第七个状态位是PE,表示结果中1的个数为偶数。
第八个状态位是NC,表示没有发生最高位向自然位的进位。

我们再在此基础上加上一个数让它发生溢出来看一次标志寄存器的变化情况。
5
可以看到我给BBBBH加上一个4445H得到的结果如AX中所示,为0000H。

  • 标志位NV告诉我们,结果没有溢出。(溢出只可能发生在符号位相同的情况下进行的运算,而BBBBH符号位为1,4445H符号位为0,所以被认为不溢出)
  • 标志位PL告诉我们最高位为0
  • 标志位ZR告诉我们结果为0
  • 标志位AC告诉我们发生了低四位向高四位的进位
  • 标志位PE告诉我们结果中1的个数为偶数(0个)
  • 标志位CY告诉我们发生了最高位向自然位的进位

step 3.总结

  • 经过学习之后发现汇编真的非常有意思,能够给人真正窥探到天机并且能够随心所欲操控这台计算机的感觉。并且计算机cpu内部的运行原理也十分有意思。
  • 需记忆各种寻址方式的寻址方法,特别是各种特殊情况,比如:

如果BP参与到寻址当中,则段寄存器默认为SS,其他情况几乎均为DS。

  • 需要记忆各种debug模式下的汇编指令,例如:

A指令:编写代码的指令,不需要经过繁琐的汇编,链接,在运行等过程,可以在debug模式下直接进行编写。
D指令:查看段内容,后面加上段跨越符就可以查看任意段的内容。
T指令:单步运行。
P指令:单步运行,遇到子程序或者中断程序一次性执行完。
R指令:查看或者修改寄存器内容。
U指令:将机器代码进行反汇编得到汇编代码。

  • 10
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
5.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。 5.2 编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序输出 5.3 将AX寄存器16分成4组,每组4,然后把这四组分别放在AL、BL、CL、DL。 5.4 试编写程序,要求比较两个字符串STRING1和STRING2所含字符是否相同,若相同则显示‘MATCH’,若不相同则显示‘NOT MATCH’。 5.5 试编写程序,要求能从键盘接收一个N,然后响铃N次。 5.6 编写程序,将一个包含有20个据的组M分成两个组:正组P和负组N,并分别把这两个据的个显示出来。 5.7 试编制一个汇编语言程序,求出首地址为DATA的100D字的最小偶,并把它放在AX。 5.8 把AX存放的16二进制K看作是8个二进制的“四分之一字节”。试编写一个程序,要求一下值为3(即11B)的四分之一字节,并将该在终端上显示出来。 5.9 试编写汇编语言程序,要求从键盘接收一个的十六进制,并在终端上显示与它等值的二进制。 5.10 设有一段英文,其字符变量名为ENG,并以$字符结束。试编写程序,查对单词SUN在该文的出现次,并以格式”SUNXXXX“显示出次。 5.11 从键盘输入一系列以$为结束的字符串,然后对其的非字字符进行计,并显示出计结果。 5.12 有一个首地址为MEM的100D字组,试编制程序删除所有为零的项,并将后续项向前压缩,最后将组的剩余部分补上零。 5.13 在STRING到STRING+99单元存放着一个字符串,试编制一程序测试该字符串是否存在字,如有,则把CL的第五置1,否则置0. 5.14 在首地址为TABLE的按递增次序存放着100H个16补码,试编写一个程序把出现次最多的及其出现的次分别放在AX和CX。 5.15 据段已定义了一个有N个字据的组M,试编写程序求出M绝对值最大的,把它放在据段的M+2n单元,并将该的偏移地址存放在M+2(n+1)单元。 5.16 在首地址为DATA的字,存放了100H个16补码,试编写一个程序求出它们的平均值放在AX寄存器;并求出有多少个小于此平均值,将结果放在BX寄存器。 5.17 试编写一个程序,把AX的十六进制转换为ASCII码,并将对应的ASCII码依次存放到MEM的四个字节,例如:当(AX)=2A49H时,程序执行完后,MEM的4个字节的内容为39H,34H,41H和32H。 5.18 把0~100D之间的30个存入以GRADE为首地址的30个字,GRADE+i表示学号i+1的学生的成绩。另一个组RANK为30个学生的名次表,其RANK+i的内容是学号为i+1的学生的名次。编写程序,根据GRADE的学生成绩,将学生名次填入RANK。 5.19 已知组A包含15个互不相等的整,试编写程序,把既在A又在B出现的整存在于C。 5.20 设在A,B和C单元存放着三个,若三个都不是0,则求出三树之和并存放于D单元;其一个为0,则把其他两个也清零。试编写程序

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值