在51单片机中,A和ACC的具体的关系是什么呢

初学单片机,在编译,仿真时,SFR中的ACC的值变化,怎么不是A的值变化呢有什么直接的关系... 初学单片机,在编译,仿真时,SFR中的ACC的值变化,怎么不是A的值变化呢
有什么直接的关系
展开
 我来答
七西的0u
推荐于2017-09-09 · 知道合伙人教育行家
七西的0u
知道合伙人教育行家
采纳数:1042 获赞数:21181
作为一名资深教育观察家,知名高考志愿填报专家。对高考政策,招生动态,以及志愿填报有着独到的见解。

向TA提问 私信TA
展开全部
A和ACC的实质是一样的,对应地址都是0E0H,
只是汇编在使用时,在格式上取了两个名字。
你看看它们的使用方法,有的地方用A,有的地方用ACC,会发现有一定的规律。
当其要进行位表示时,必须用ACC,
比如要写成ACC.7,而不能写成A.7
但当其作为8位二进制数时,ACC和A都能用
但还是有区别
比如 INC ACC和INC A 都能用
还有PUSH ACC POP ACC也可以写成PUSH A和POP A
当然,我们学汇编时,它主要是讲了一个格式,可能书上只讲到PUSH ACC,没有讲到PUSH A,没讲到并不代表它不能用。
北京康思
2018-09-20 广告
1、基本功能。市面上的电子负载均有基本的四项功能:恒流、恒压、恒阻和恒功率(安捷伦没有恒功率)。在功能基本相同,精确度相差不大的情况下,怎么判断是否符合要求呢?CHROMA和博计的电子负载只有一套工作电路,就是恒流功能。其他功能是根据欧姆定... 点击进入详情页
本回答由北京康思提供
maajt
2009-04-03 · TA获得超过502个赞
知道小有建树答主
回答量:97
采纳率:100%
帮助的人:121万
展开全部
A和ACC的实质是一样的,对应地址都是0E0H,
只是汇编在使用时,在格式上取了两个名字。
你看看它们的使用方法,有的地方用A,有的地方用ACC,会发现有一定的规律。
当其要进行位表示时,必须用ACC,
比如要写成ACC.7,而不能写成A.7
但当其作为8位二进制数时,ACC和A都能用
但还是有区别
比如 INC ACC和INC A 都能用
还有PUSH ACC POP ACC也可以写成PUSH A和POP A
当然,我们学汇编时,它主要是讲了一个格式,可能书上只讲到PUSH ACC,没有讲到PUSH A,没讲到并不代表它不能用。
我对它们的理解是:除位操作以外,其余通用。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2019-05-18
展开全部
  1. 累加器A与ACC区别

  2. 累加器写成A或ACC在51汇编语言指令中是有区别的。

  3. ACC在汇编后的机器码必有一个字节的操作数,是累加器的字节地址E0H,A在汇编后则隐含在指令操作码中。

  4. 所以在指令中A不能用ACC来替代,而对A的特殊功能寄存器直接寻址和累加器某一位的寻址要用ACC,而不能写成A。

  5. 例如,指令INC A的机器码是04H,属于寄存器寻址,写成ACC后则成了INC DIRECT的格式,对应机器码为05E0H。

  6. A和ACC都表示累加器,但A是累加器的代号,在指令中默认是无地址的,而ACC是累加器在中的直接地址(OEH),可出现在用直接寻址的任何地方,例如:   

    PUSH    ACC                               POP    ACC

  7. 类似:工作寄存器R0~R7在指令中也有两种不同的写法,生成的机器码也不同,如:

  8. MOV       40H,R0       , 

  9. MOV       40H,00H

  10. 假设当前工作寄存器为0组,前者属于寄存器寻址,后者属于存储器直接寻址。但R0和00H的级别不同,00H只是RAM区的一个普通单元,其读写速度要比慢得多。微型计算机内部通常设置工作寄存器组,运算的结果可以放在寄存器中而不必每次都放到存储器里,可以提高机器的工作速度。其实寄存器也是一种存储器,只不过它是CPU中的部件,速度最快而已。

  11. 寄存器和一般的存储器是混叠的,同一单元用不同的指令,它就会执行不同的功能。

  12. 一般的说法:A表示了累加器中的内容【寄存器寻址】;ACC表示了累加器的地址【直接寻址】。

  13. A和ACC的实质是一样的,对应地址都是0E0H,只是汇编在使用时,在格式上取了两个名字。使用有一定的规律:

  14. 当其要进行位表示时,必须用ACC,比如要写成ACC.7,而不能写成A.7;

  15. 但当其作为8位二进制数时,ACC和A都能用,但还是有区别:比如 INC ACC和INC A 都能用,还有PUSH ACC,POP ACC不可以写成PUSH A和POP A

  16. 在Keil C中用了这样一个命令:PUSH     A ,汇编时提示错误,后来我把PUSH     A 改为 PUSH    ACC 就可以通过了,请问这是什么回事?A与ACC是同一个寄存器吗?

  17. 所谓“A”是相关指令对累加器A的缺省指定(不占操作数指令),而PUSH和POP没有缺省指定累加器,要访问累加器就必须采用其所允许的直接寻址方式,“ACC”就是累加器A的地址。PUSH 是直接寻址,后面一定跟的是直接地址。你可以看到reg51.h中ACC的直接地址是0xe0;也可以PUSH E0h;累加器有A、ACC和E0H三种表示形式,分属两种不同的寻址方法,使用A时,为寄存器寻址,指令码为04H,使用ACC和E0H时,为直接寻址,指令码为05E0H。可A的位7,为什么非得用ACC.7而不用A.7。这与位寻址有关系,位地址有四种:直接位地址;字节地址加位序号;位名称;特殊寄存器加位序号。

  18. 为什么push acc必须用acc,而不能用a,相反movx @dptr,a只能用a,而不能用ac?acc和a有什么区别?ACC is register。A is a unseparatable part of opcode。

  19. 在mov指令中可通用,用"a"时为2字节1周期;用"acc"时为3字节2周期。 

  20. 尽管物理地址相同,但push是对寄存器操作,而movx是对累加器操作。 

  21. 汇编结果:"inc a"为"04h"运行时间1周期;"inc acc"为"05h,e0h"运行时间2周期。 

  22. 通俗的解释为:acc是地址为E0H的寄存器,A是标准的无地址的累加器,自然后者便捷,但两者在值上互为镜像

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sanjinluo
2009-04-03 · TA获得超过4718个赞
知道大有可为答主
回答量:3404
采纳率:0%
帮助的人:1074万
展开全部
还有一点,在一下指令中只能使用ACC作为累加器的符号
INC ACC
POP ACC
PUSH ACC
访问ACC的某一位时
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
myd986
2018-06-09
知道答主
回答量:7
采纳率:0%
帮助的人:2.6万
引用软件外包介绍的回答:
A和ACC的实质是一样的,对应地址都是0E0H,
只是汇编在使用时,在格式上取了两个名字。
你看看它们的使用方法,有的地方用A,有的地方用ACC,会发现有一定的规律。
当其要进行位表示时,必须用ACC,
比如要写成ACC.7,而不能写成A.7
但当其作为8位二进制数时,ACC和A都能用
但还是有区别
比如 INC ACC和INC A 都能用
还有PUSH ACC POP ACC也可以写成PUSH A和POP A
当然,我们学汇编时,它主要是讲了一个格式,可能书上只讲到PUSH ACC,没有讲到PUSH A,没讲到并不代表它不能用。
展开全部
PUSH ACC正确PUSH A错误
因为A是作为寄存器来用,是寄存器寻址方式;第一条指令是直接寻址方式,因此是正确的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式