lab2000p程序s5.asm

程序:(没看懂是怎么跳转的。请高手指教。)

;程序跳转表

           org 0

           ljmp Start

       Func0:

           mov a,#0

           ret

       Func1:

           mov a,#1

           ret

       Func2:

           mov a,#2

           ret

       Func3:

           mov a,#3

           ret

 

       FuncEnter:

           add a,acc

           mov dptr,#FuncTab

           jmp @a+dptr

       FuncTab:

           ajmp Func0

           ajmp Func1

           ajmp Func2

           ajmp Func3

       Start:

           mov a,#0

           call FuncEnter

           mov a,#1

           call FuncEnter

           mov a,#2

           call FuncEnter

           mov a,#3

           call FuncEnter

           ljmp $

 

           end    

 

程序解释:

1,add a,acc

就是A和A 里面内容相加 。ACC就是A的全称,规定有时要写成ACC,比如 PUSH ACC 和POP ACC 这对指令,不能写成PUSH A.。。。。

2,

 

知识点:

1,A和ACC区别

 

 

累加器写成A或Acc在51汇编语言指令中是有区别的。Acc在汇编后的机器码必有一个字节的操作数,是累加器的字节地址E0H,A在汇编后则隐含在指令操作码中。所以在指令中A不能用Acc来替代,而对A的特殊功能寄存器直接寻址和累加器某一位的寻址要用Acc,而不能写成A。例如,指令INC A的机器码是04H,写成Acc后则成了INC direct的格式,对应机器码为05E0H。

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

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

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

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

一般的说法:A表示了累加器中的内容 【寄存器寻址】

                ACC表示了累加器的地址   【直接寻址】

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,没讲到并不代表它不能用。

我对它们的理解是:除位操作以外,其余通用。

 

 

 

 

你可能感兴趣的:(ASM)