关于汇编语言累加器的使用问题

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;
}

以上是关于关于汇编语言累加器的使用问题的主要内容,如果未能解决你的问题,请参考以下文章

Python语言程序设计之一--for循环中累加变量是否要清零

求 6502 汇编指令集

汇编语言中 寄存器有啥作用 怎么用

用C语言怎么计算1到100的累加

c语言1到100累加和

c语言 求1到100的累加数(用两种方法)