arm 的 大致的架构。

LDR{条件} 目的寄存器, <存储器地址>
功能: 将存储器的一个32的数据,保存到寄存器中。
但是这条指令还有另外一个作用。
如果 目的寄存器是PC的话,而从内存中读到的数据是一块内存的地址,那么这个指令实现的功能与B , BL 的作用是一样的。
LDR 	R0,[R1]           		;将存储器地址为R1的字数据读入寄存器R0。
LDR 	R0,[R1,R2]      		;将存储器地址为R1+R2的字数据读入寄存器R0。
LDR 	R0,[R1,#8]      		;将存储器地址为R1+8的字数据读入寄存器R0。
LDR 	R0,[R1,R2] !     		;将存储器地址为R1+R2的字数据读入寄存器R0,并将
                                    ;新地址R1+R2写入R1。
LDR 	R0,[R1,#8] !     		;将存储器地址为R1+8的字数据读入寄存器R0,并将新
                                    ;地址R1+8写入R1。
LDR 	R0,[R1],R2	     		;将存储器地址为R1的字数据读入寄存器R0,并将新地
                                    ;址R1+R2写入R1。
LDR 	R0,[R1,R2,LSL#2]!	    ;将存储器地址为R1+R2×4的字数据读入寄存器R0,
                                    ;并将新地址R1+R2×4写入R1。
LDR 	R0,[R1],R2,LSL#2		;将存储器地址为R1的字数据读入寄存器R0,并将新地
                                    ;址R1+R2×4写入R1。对于这个指令一定要与 C语言的 * 操作符联系起来。
举例:
int * ptr;
x=*ptr++;
翻译成汇编就是
LDR,R0, [R1], #4
首先将以R1为内存地址的值 保存到R0中, 然后在 将R1 的值 加上4 。
所以我最好 将 内存的地址 与内存的值, 单独出来。
然后是 STR 指令
str r0, [r1] 代表的是 , 将R0的内容,写到以R1为地址的内存中。



















