1. 在80C51单片机里面,半进位标志位AC在加减运算里面是按照有符号数还是无符号数来设置标志位
一、加法指令
1、不带进位加法指令
工作寄存器、内部RAM单元内容或立即数的8位无符号二进制数和累加器A中数相加,所得和存放于累加器A中,当和的第3、7位有进位时,分别将AC,CY标志位置1;否则为0。 上述指令的执行将影响标志位AC、CY、OV、P。
对于无符号数,进位标志位CY=1,表示溢出;CY=0表示无溢出。带符号数运算的溢出取决于第6、7位中有一位产生进位,而另一位不产生进位,溢出标志位OV置“1”否则被清“0”。OV=1表示两个正数相加,和变为负数,或两个负数相加,和变为正数的错误结果。
2、带进位加法指令
将累加器A内容加当前CY标志位内容,再加无符号单字节的数,和存于累加器A中。当运算结果第3、7位产生进位溢出时,则分别置位AC、CY和OV标志位。本指令执行将影响标志位AC、CY、OV、P。
二、减法指令
1、带借位减法指令
带借位减法指令SUBB,从累加器A中减去进位标志位CY和指定的变量,结果在累加器A中,若第七位有借位,则置位位CY,否则CY清0。若第3位有错位,则置位辅助进位标志AC,否则清0 AC。若第7和第6位中有一位需借位,而另一位不借位,则置位溢出标志OV。溢出位OV用于带符号的整数减法,它表示(OV=1)一个正数减负数结果为负数;或一个负数减正数结果为正数的错误结果。
三、乘法指令
本指令将累加器A和寄存器B中二个8位无符号整数进行相乘,16位乘积的低8位存于A中,高8位存于B中,如果乘积大于255(0FFH),即B的内容不为0时,则置位溢出标志位OV,否则清“0”OV。进位标志位CY总是清“0”。
四、除法指令
本指令将累加器A中8位无符号整数除以B寄存器中8位无符号整数,所得结果商的整数部分存于A中,整数作数部分存于寄存器B中。清“0”CY和OV标志位。当除数(B中内容)为00H时,则执行结果将为不定值,即执行结果送往A和B中的为不定值,且置位溢出标志位OV。在任何情况下,均清“0”CY。
2. 单片机电路板上ACLED含义是什么
这个指示灯代表:单片机正常工作,没有死机,如果亮了代表单片机程序正常。
3. 单片机中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是标准的无地址的累加器,自然后者便捷,但两者在值上互为镜像
4. 单片机中,cy ac ov有什么用 我知道他们是来表示借位和溢出的,可是表示出来了又有什么用呢
两个数相加减,就可能产生进位或者借位,这样可用于比较两个数的大小;
想了解这些标记位,最好结合编程语言来学习
5. 电流里AC和DC分别代表什么
AC 是英文Alternating Current 的首字母缩写,意为:交流电流,简称交流电 或交流。
DC 是英文Direct Current 的首字母缩写,意为:直流电流,简称直流电 或直流。
电流分为交流电流和直流电流。
交流电:插电源的用电器使用的是交流电
直流电:使用外置电源的用电器用的是直流电
交流电一般是在家庭电路中有着广泛的使用,有220V的电压,属于危险电压。
直流电则一般被广泛使用于手机(锂电池)之中。像电池(1.5V),锂电池,蓄电池等被称之为直流电。
物理上规定电流的方向,是正电荷定向移动的方向。电流运动方向与电子运动方向相反。
电荷指的是自由电荷,在金属导体中的自由电荷又叫自由离子,在酸,碱,盐的水溶液中是正离子和负离子。
在电源外部电流沿着正电荷移动的方向流动。在电源内部由负极流回正极。
(5)单片机ac扩展阅读
安培(André-Marie Ampère 1775~1836年),法国物理学家,对数学和化学也有贡献。1775年1月22日生于里昂一个富商家庭。年少时就显出数学才能。他的父亲信奉J.J.卢梭的教育思想,供给他大量图书,令其走自学的道路,于是他博览群书,吸取营养;卢梭关于植物学的着作燃起了他对科学的热情。
安培小时候记忆力极强,数学才能出众。他父亲受卢梭(1712-1778)的教育思想的影响很深,决定让安培自学,经常带他到图书馆看书。安培自学了《科学史》、《网络全书》等着作。他对数学最着迷,13岁就发表第一篇数学论文,论述了螺旋线。
1799年安培在里昂的一所中学教数学。1802年二月安培离开里昂去布尔格学院讲授物理学和化学,四月他发表一篇论述赌博的数学理论,显露出极好的数学根底,引起了社会上的注意。后来应聘在拿破仑创建的法国公学任职。
1808年安培任法国帝国大学总学监,1809年任巴黎工业大学数学教授。1814年当选为法国科学院院士。1824年任法兰西学院实验物理学教授。1827年当选为英国伦敦皇家学会会员。他还是柏林、斯德哥尔摩等科学院的院士。
6. mcs-51系列单片机psw的辅助进位ac
在做加法运算时,若低半字节有进位,则ac=1,否则ac=0.
低半字节大概是指一个字节8位的低4位,也就是后面的低4位。
那么如果00001000+00001000,c=0,ac=1,ov=1,发生溢出,也就是说整体没溢出,但是低4位有溢位所以ac=1 因为ac=1 所以OV=1
7. 在51单片机中,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是标准的无地址的累加器,自然后者便捷,但两者在值上互为镜像
8. 51单片机如何判断ac dc
单片机是认不了这些东西,它只认得数字信号,对于AC,DC这些东西,你需要另外加电路转换的,再告诉单片机
9. 单片机汇编语言中 CY AC OV 分别是什么意思
单片机汇编语言中
CY(PSW.7)是进位或借位,来源于最近一次算术指令或逻辑指令执行结果。
AC(PSW.6)是辅助进位或辅助借位,用于BCD码的十进制调整运算。
OV(PSW.2)是溢出位。在执行算术指令时,指示运算是否产生溢出。
10. 单片机中乘法指令影响ac吗
不影响,只影响OV和C。