关于汇编语言累加器的使用问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于汇编语言累加器的使用问题相关的知识,希望对你有一定的参考价值。
看见汇编中有人使用累加器。但我却不知道累加器是什么东西?和寄存器又有什么区别吗?另外怎么用累加器呢?谢谢了~~
在学术上,累加器是 AX(Accumulator,取其字第一个字母,所以叫AX),而在实际的用途上,除了AX 外,BX,CX,DX,SI,DI 都可以当累加器使用,并没有严格的规定。AX在使用上是很广泛的,除了我们的普通累加的使用外,它还起着一个指定中断功能的作用,例如:
mov ah,9
mov dx,offset str
int 21
它就起了一个输出指定字串的作用。
除此外,在某些数学的计算上,它也是一个被指定使用的存储器,例如:
mov ax,9
mov cl,3
div cl
在这里,它就是一个被除数。
随着你学习的进阶,你会慢慢发觉,AX除了一些被指定使用的情况下使用外,在其他的累加使用上和其它的存储器并没有分别。 参考技术A 累加器是寄存器的一种
系统指定的累加器是AX
做加法速度快 参考技术B 累加器的opcode经过特殊优化,比其他的寄存器的opcode短一个字节。
因此从内存读取指令的速度会快一些。 参考技术C 累加器属于寄存器,但存取速度稍快,是一些指令的默认第二操作数如乘法指令,也可作为普通寄存器使用 参考技术D 累加器是寄存器中的一个,一般是AX。
累加校验和C语言实现
发送方:对要数据累加,得到一个数据和,对和求反,即得到我们的校验值。然后把要发的数据和这个校验值一起发送给接收方。
接收方:对接收的数据(包括校验和)进行累加,如果得到0(关于网上说这里需要加1,本人通过测试发现,不需要累加),那么说明数据没有出现传输错误。(注意,此处发送方和接收方用于保存累加结果的类型一定要一致,否则加1就无法实现溢出从而无法得到0,校验就会无效)
测试如下:
发送方:
接收方:
测试工具链接:http://www.metools.info/code/c128.html
原始代码如下:
/* 发送方测试代码 */
uint8_t Send_CheckSum(uint8_t *str, int str_length)
{
uint8_t CheckSum_Value = 0;
int i = 0;
for(i = 0; i < str_length; i++)
{
CheckSum_Value += str[i];
}
CheckSum_Value = ~CheckSum_Value;
return CheckSum_Value;
}
/* 接收方测试代码 */
uint8_t Recv_CheckSum(uint8_t *str, int str_length)
{
uint8_t CheckSum_Value = 0;
int i = 0;
for(i = 0; i < str_length; i++)
{
CheckSum_Value += str[i];
}
return CheckSum_Value;
}
以上是关于关于汇编语言累加器的使用问题的主要内容,如果未能解决你的问题,请参考以下文章