单片机汇编程序执行效率高,最节省程序存储器空间,可以自已分配存储空间,做到真正不浪费一个存储单元。如果程序很小,用汇编写程序很快,但如果程序实现的功能很复杂,使用汇编来编就有一些吃力。 使用汇编时,有一些误区, 在编程前心里一定要明白,特别是刚刚学习汇编的朋友。
误区一: DJNZ A,#REF,此处不能用累加器ACC,可以用端口地址、寄存器组地址R0~R7、或其他存储单元地址。如果是在Keil的环境下, 用了,编译器会帮我们发现这个错误;
误区二:CLR P0,此处不能用P0,或者是一个表示单元的地址,CLR清零指令,可以清除累加器ACC的值,CLR只能用于清ACC为0、进位位、 直接寻址位为0,给我们一种错觉,好像要把某个单元的内容变为零,用CLR会比较爽,那么,程序运行起来,你就别指望CPU会把哪个单元 的值变为0,执行后,它的值不会发生任何改变,并且Keil编译器不会作任何提示,不知道其他的编译环境会不会提示。只有老老实实的, 用MOV P0,#0指令实现,或者用CLR A,MOV P0,A两条指令实现。
误区三:RECVBUF EQU 35H,如果定义了一个接收缓冲区的地址,为了引用方便,这个地址可以插在其他的变量中间,而不必后 面一定要紧跟着接收缓冲区的单元,这只是定义一个接收缓冲区开始的地址从35H单元开始。这时心里一定要明白,Mov A,RECVBUF和 MOV A,#(RECVBUF)的含义,否则在使用时,如果用错了,会产生很严重的后果,把其他单元的内容给改变了还不知道,导致程序跑飞了或完 全乱跑了。前面一句相当于:MOV A,35H,意思是把存储单元35H中的内容送ACC,而后面一句相当于MOV A,#35H,意思是把ACC的内容变为一个 立即数35H。此处的地址就跟写上位机程序的指针一个意思,如果此处理解了,对我们理解指针的含义有很大的帮助。 还有,如果用EQU定义的是一个表示偏移量的代号,相当于C语言里的一个宏定义,如: RECVBUF EQU 35H SYNCH EQU 01H RECVLEN EQU 02H FUNCA EQU 03H SYNCH表示从接收缓冲区开始的第一个字节为同步头,后面的依次类推,则在使用时一定要加上立即数标志,如: MOV A,RECVBUF ADD A,#(SYNCH) 否则就把其他单元的内容改了,或者取到了取它单元的内容。