汇编编程问题求大佬
本人大一学习汇编,刚刚讲到串处理,老师也没多讲有几道题不太明白,希望大佬指点一下1、将内存2000H: 0000H~2000:0FFFH范围内的内存单元清零,用串写入指令实现。
2、将内存2000H: 0000H~2000:0FFFH范围内的内存单元循环存入'A’ ~‘F’ 字符,用串写入指令实现。
3、将内存2000H: 0000H~ 2000:0FFFH范围内的内存单元中的大写字符转换为小写字符。
串?你说的是movsb吗?我忘记用法了。它的意思就是把某些东西按顺序放入另一个地方。就是以字节为单位放进去的。好像依赖哪个寄存器来决定移多少数量过去。而大小写转换,查ACSII码表。好像大写比小写少30还是20的值 的。A是61开头吧?好像a是41开头。反正是这样的。你找到规律,用程序算就行了。当然,如果有大有小,那么还得判断谁大谁小。不过,有个方法却是不用判断,你等我查查 movsb正是串传送指令。当DF=0时,每次di和si递增。当DF=1时,si和di每次递减。正好利用这个功能,设置DF=0,然后就可以把ds:si往es:di中传了。cld:清空df,意思就是DF=0了。移动多少次,即长度,在CX中。可以mov cx,0FFFh..由于是一个字节这样传的。清零就比较简单的。上一个是0,后面也跟着0,那么:mov 2000:0,0当然你得这么写:movds,2000h mov si,0 movds:,0 moves,2000h movdi,1 然后随心所欲地movsb 因为从0到FFF,个数为FFF+1个。我把0已经干掉了。只剩FFF了。CX就填FFF。当然,只有一次,要重复,一下就想到loop。但我们用rep。直接这样写repmovsb就行了。不需要什么标号什么的。 存入A到F也可以这么干。我刚才清零就是这么干的,不过只重复一个。你这有几个。好办啊!先把这几个字符写进去。再movsb,就可以重复了。刚才si和di隔了一个。现在A到F有好几个。那么si和di就得隔好几个。 想起来了。大小写字母除了数值固定的相差多少外,还有就是它们的二进制形式,只有其中一位不同。这样可以利用and或者or命令,将那个不同位死变成小写那一位。如果要变0就把那一位and 0。如果要变1就把那一位or 1。因为and有一位为0即为0。相同位上的比较。。你都给0了,那么不管它之前是什么,它都将成为0。而or正好相反,有一位为1即为1。你 or1了,那么不管那位是什么,它都将变成1。这样就不用管它们之前是大写还是小写了,想变啥就可以统统变成啥 405794672 发表于 2020-4-19 16:21
想起来了。大小写字母除了数值固定的相差多少外,还有就是它们的二进制形式,只有其中一位不同。这样可以利 ...
我懂了,谢谢大佬,开始的时候就没考虑串指令影响的寄存器
页:
[1]