⑴ 单片机里的ACC是什么
累加器的意思。 累加器ACC是一个8位的存储单元,是用来放数据的。但是,这个存储单元有其特殊的地位,是单片机中一个非常关键的单元,很多运算都要通过ACC来进行。以后在学习指令时,常用A来表示累加器。但有一些地方例外,比如在PUSH指令中,就必须用ACC这样的名字。一般的说法,A代表了累加器中的内容、而ACC代表的是累加器的地址 ACC---是指的单片机的累加器,具有特殊用途的二进制8位寄存器。A---也属于累加器的简写形式。ACC和A没有区别。
⑵ 单片机push acc和pop acc是什么意思
PUSH是压栈命令,POP是出栈命令。
单片机将各功能部件集成在一块晶体芯片上,集成度很高,体积自然也是最小的。芯片本身是按工业测控环境要求设计的,内部布线很短,其抗工业噪音性能优于一般通用的CPU。单片机程序指令,常数及表格等固化在ROM中不易破坏,许多信号通道均在一个芯片内,故可靠性高。
特征:
(1)单片机的体积比较小, 内部芯片作为计算机系统,其结构简单,但是功能完善,使用起来十分方便,可以模块化应用。
(2)单片机有着较高的集成度,可靠性比较强,即使单片机处于长时间的工作也不会存在故障问题。
(3) 单片机在应用时低电压、低能耗,是人们在日常生活中的首要选择, 为生产与研发提供便利。
(4)单片机对数据的处理能力和运算能力较强,可以在各种环境中应用,且有着较强的控制能力。
以上内容参考:网络-单片机
⑶ 在单片机中ACC是什么
ACC累加器=A
ACC.0=E0H
ACC.0就是ACC的第0位。Acc可以位寻址。
累加器ACC是一个8位的存储单元,是用来放数据的。但是,这个存储单元有其特殊的地位,是单片机中一个非常关键的单元,很多运算都要通过ACC来进行。以后在学习指令时,常用A来表示累加器。但有一些地方例外,比如在PUSH指令中,就必须用ACC这样的名字。一般的说法,A代表了累加器中的内容、而ACC代表的是累加器的地址
ACC---是指的单片机的累加器,具有特殊用途的二进制8位寄存器。A---也属于累加器的简写形式。ACC和A没有区别
⑷ 51单片机中ACC怎么用
A和ACC的实质是一样的,对应地址都是0E0H,
只是汇编在使用时,在格式上取了两个名字。
你看看它们的使用方法,有的地方用A,有的地方用ACC,会发现有一定的规律。
当其要进行位表示时,必须用ACC,
比如要写成ACC.7,而不能写成A.7
但当其作为8位二进制数时,ACC和A都能用
但还是有区别
比如 INC ACC和INC A 都能用
ACC是地址的调用
而A是累加器调用
由于PUSH、POP 是直接寻址,后面一定跟的是直接地址
所以在进栈和出栈的时候 不能用A 只能用Acc
有这么一说
累加器有A、ACC和E0H三种表示形式,分属两种不同的寻址方法,使用A时,为寄存器寻址,指令码为04H,使用ACC和E0H时,为直接寻址,指令码为05E0H
INC A 是寄存器寻址
INC A 是单字节指令,转换成机器码是:04H,机器码中没有明确指出操作数,隐含操作
数是累加器A,所以把这种方式寻址叫寄存器寻址。
INC ACC是直接寻址
INC ACC 是双字节指令,转换成机器码是:05H,E0H。机器码中包含了累加器A的地址E0H
这个 E0H 可以换成其他直接地址,所以这种方式寻址叫直接寻址。
PUSH 和 POP 指令只支持直接寻址,所以不能用 A
PUSH ACC 机器码:C0H E0H
POP ACC 机器码:D0H E0H
⑸ 关于单片机程序中的ACC。
累加器A为8位寄存器,通过暂存器与ALU相连,是最常用的寄存器,功能较多,既可以存放操作数,也可以存放中间结果,一些双操作数指令中,逻辑运算指令的运算结果都存放在累加器A或AB中,在作为直接寻址时 ,在程序中要写成ACC.
⑹ 单片机中A与Acc有什么区别
累加器A与ACC区别
累加器写成A或ACC在51汇编语言指令中是有区别的。
ACC在汇编后的机器码必有一个字节的操作数,是累加器的字节地址E0H,A在汇编后则隐含在指令操作码中。
所以在指令中A不能用ACC来替代,而对A的特殊功能寄存器直接寻址和累加器某一位的寻址要用ACC,而不能写成A。
例如,指令INCA的机器码是04H,属于寄存器寻址,写成ACC后则成了INCDIRECT的格式,对应机器码为05E0H。
A和ACC都表示累加器,但A是累加器的代号,在指令中默认是无地址的,而ACC是累加器在中的直接地址(OEH),可出现在用直接寻址的任何地方,例如:
PUSHACC
POPACC
类似:工作寄存器R0~R7在指令中也有两种不同的写法,生成的机器码也不同,如:
MOV40H,R0,
MOV40H,00H
假设当前工作寄存器为0组,前者属于寄存器寻址,后者属于存储器直接寻址。但R0和00H的级别不同,00H只是RAM区的一个普通单元,其读写速度要比慢得多。微型计算机内部通常设置工作寄存器组,运算的结果可以放在寄存器中而不必每次都放到存储器里,可以提高机器的工作速度。其实寄存器也是一种存储器,只不过它是CPU中的部件,速度最快而已。
寄存器和一般的存储器是混叠的,同一单元用不同的指令,它就会执行不同的功能。
一般的说法:A表示了累加器中的内容【寄存器寻址】;ACC表示了累加器的地址【直接寻址】。
A和ACC的实质是一样的,对应地址都是0E0H,只是汇编在使用时,在格式上取了两个名字。使用有一定的规律:
当其要进行位表示时,必须用ACC,比如要写成ACC.7,而不能写成A.7;
但当其作为8位二进制数时,ACC和A都能用,但还是有区别:比如INCACC和INCA都能用,还有PUSHACC,POPACC不可以写成PUSHA和POPA
在KeilC中用了这样一个命令:PUSHA,汇编时提示错误,后来我把PUSHA改为PUSHACC就可以通过了,请问这是什么回事?A与ACC是同一个寄存器吗?
所谓“A”是相关指令对累加器A的缺省指定(不占操作数指令),而PUSH和POP没有缺省指定累加器,要访问累加器就必须采用其所允许的直接寻址方式,“ACC”就是累加器A的地址。PUSH是直接寻址,后面一定跟的是直接地址。你可以看到reg51.h中ACC的直接地址是0xe0;也可以PUSHE0h;累加器有A、ACC和E0H三种表示形式,分属两种不同的寻址方法,使用A时,为寄存器寻址,指令码为04H,使用ACC和E0H时,为直接寻址,指令码为05E0H。可A的位7,为什么非得用ACC.7而不用A.7。这与位寻址有关系,位地址有四种:直接位地址;字节地址加位序号;位名称;特殊寄存器加位序号。
为什么pushacc必须用acc,而不能用a,相反movx@dptr,a只能用a,而不能用ac?acc和a有什么区别?ACCisregister。Aisaunseparatablepartofopcode。
在mov指令中可通用,用"a"时为2字节1周期;用"acc"时为3字节2周期。
尽管物理地址相同,但push是对寄存器操作,而movx是对累加器操作。
汇编结果:"inca"为"04h"运行时间1周期;"incacc"为"05h,e0h"运行时间2周期。
通俗的解释为:acc是地址为E0H的寄存器,A是标准的无地址的累加器,自然后者便捷,但两者在值上互为镜像
⑺ 单片机中,ACC寄存器是什么用途怎么使用具体存在哪个地方
ACC(Accumulator)是累加器A缩写。累加器A是一个具有特殊用途的二进制8位寄存器,专门用来存放操作数或运算结果。在CPU执行某种运算前,两个操作数中的一个通常应放在累加器A中,运算完成后累加器A中便可得到运算结果。
对累加器A的单操作数的逻辑操作指令
对累加器A的单操作数的逻辑操作指令如下所示:
1、CLRA;(A)=0
这条指令的功能是将累加器A的内容清零,即(A)=0,不影响Cy标志位、AC标志位和OV标志位,只影响P标志位。
2、CPLA;(A)A
这条指令的功能是将累加器A的内容逐位逻辑取反,不影响标志位。
3、RLA
这条指令的功能是将累加器A的内容向左循环移1位,不影响标志位。
4、RRA
这条指令的功能是将累加器A的内容向右循环移1位,不影响标志位。
5、RLCA
这条指令的功能是将累加器A的内容和进位标志位Cy一起向左循环移1位,不影响AC标志位、OV标志位。
6、RRCA
这条指令的功能是将累加器A的内容和进位标志位Cy一起向右循环移1位,不影响AC标志位、OV标志位。