导航:首页 > 操作系统 > 单片机中a

单片机中a

发布时间:2022-02-15 09:43:53

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

  1. 累加器A与ACC区别

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

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

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

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

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

    PUSHACC POPACC

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

  8. MOV40H,R0,

  9. MOV40H,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都能用,但还是有区别:比如INCACC和INCA都能用,还有PUSHACC,POPACC不可以写成PUSHA和POPA

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

  17. 所谓“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。这与位寻址有关系,位地址有四种:直接位地址;字节地址加位序号;位名称;特殊寄存器加位序号。

  18. 为什么pushacc必须用acc,而不能用a,相反movx@dptr,a只能用a,而不能用ac?acc和a有什么区别?ACCisregister。Aisaunseparatablepartofopcode。

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

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

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

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

⑵ 单片机汇编语言中A是什么意思

1 是累加器的汇编名称
2 是数据 二进制是1010 十进制是10 十六进制是A

⑶ 单片机中A/D功能有哪些多谢指教!

有ad带串口的单片机多的去了,你想要怎么的“高级”法?
c8051f120是51里面最高级的了。
atmega2560是avr单片机里面最高级的了。
当然上面的都是8位机器,如果你想高级就上arm,stm32或者lpc的也非常不错。

⑷ 单片机中寄存器A和B有什么区别

单片机中寄存器A和B区别为:使用不同、存放不同、他用不同。

一、使用不同

1、寄存器A:输入/输出指令必须通过寄存器A使用。

2、寄存器B:输入/输出指令不通过寄存器B,在乘法和除法运算中配合寄存器A使用。

二、存放不同

1、寄存器A:寄存器A用于存放参与算术或逻辑运算的低字节执作数及运算结果。

2、寄存器B:寄存器B用于存放参与算术或逻辑运算的高字节执作数及运算结果。

三、他用不同

1、寄存器A:寄存器A也可在循环和串操作中充当累计器。

2、寄存器B:寄存器B也可用作间接寻址的地址寄存器和基地址寄存器。

⑸ 单片机(A)

你说的单片机,是什么型号啊?

⑹ 单片机中A与Acc有什么区别

⑺ 有谁知道单片机中RR,A是什么意思啊

在汇编中RR和RL都是移位类指令,位移类指令只能对累加器A进行移位, RR A 是指使累加器A内各位向右环移一位,例如累加器A原来各位为01111111,运行 RR A语句后,累加器A各位就变为10111111。
RL A 是指使累加器A内各位向左环移一位,例如累加器A原来各位为11111110,运行 RL A语句后,累加器A各位就变为11111101。

⑻ 单片机里的A

虽然A+DPTR是16位的,但是该地址指向的单元是一个字节。
看来你对这个指令的意义还是模模糊糊并不理解的。

⑼ 单片机里的"rl a"是什么意思

单片机里的"rl a"是循环左移指令,执行一次,累加器中的值左移一位,最高位移到最低位,比如:

MOV A,#90H

RL A

执行后,结果为(A)=21H。

(9)单片机中a扩展阅读

用到循环移位的操作时,在汇编里面是比较容易实现的,ror,rol指令就行了。利用位运算进行循环移位操作比较容易理解。如果不是循环移位,使用x<<n(左移n位),x>>n右移n位。

循环移位也容易理解。比如我们有个1字节的数: x = 10111110。现在需要对其循环右移4位。也就是最后结果为x = 11101011。其实思路就是分离数据,我们需要提取出前四位1011,后四位1110。

其实需要两个数的或操作,也就是00001011,11100000,我们只要得到这两个数然后让他们就行或操作:00001011|11100000 =11101011。把10111110 右移4位变为00001011(x>>4),把10111110左移4位变为11100000(x<<4),注意移位后的“空格”是用0填充的。最后执行或操作。

⑽ 单片机C语言中a=~(1<<b)

a=~(1<<b)是什么意思?
原意:将第B位置1后取反,即清掉第B位IO
P1&=0xff;P1|=0x01中的&=和|=是什么意思
P1&=0xff:相与后传送给P1,即保持P1原值不变;
P1|=0x01:相异或与后传送给P1,即P1赋值为0x01;

阅读全文

与单片机中a相关的资料

热点内容
墨镜慧眼怎么下载厂商的app 浏览:57
iphone加密专线 浏览:489
aes产生加密文件 浏览:408
编程实现蓝牙通信 浏览:764
怎么恢复掉签的app 浏览:842
服务器部署ip地址 浏览:321
涉密场所周边安全防护距离算法 浏览:672
安卓fpse模拟器怎么设置加速 浏览:946
建行app怎么生成电子签章 浏览:508
获取当前时间javadate 浏览:73
带密码的wifi如何加密 浏览:237
服务器怎么变成阵列 浏览:718
web前端黑客技术pdf 浏览:71
育儿百科全书pdf 浏览:600
任务栏启动命令 浏览:912
编译优化等级区别 浏览:757
unix网关命令 浏览:875
想自己做网站要学编程吗 浏览:597
租个服务器开个私服需要什么 浏览:272
图片换成pdf格式 浏览:663