单片机C语言中 指针问题

Python025

单片机C语言中 指针问题,第1张

getbit是接收一位的子函数吧。

send+2+length是运算当前接收的1byte的存储地址的。

接收的数据是小端在前的,每接收一位后,通过<<j左移到当前应存储的位,然后与之前接收的数据进行或运算,就把这一位存到指定内存里去了。

1 static volatile unsigned TMR1 @ 0x0E

0x0E 是寄存器地址。 表示这个TMR1是寄存器0x0E的值。 具体这个寄存器是做什么用的,需要看你芯片的datasheet,比如 16F874A 16F877A 这个都是计数寄存器的地址。

2 PopQueue应该是一个弹出队列的函数。

将队列首弹出到msg中,返回值为PopSuccess表示取数据成功,取到的数据会存在msg中。

一般用于中断传数据给主线程。这个在主线程中接收。

3 __CONFIG(x) 一般是配置寄存器的。

INDF 和 FSR两个寄存器构成了一个间接寻址的作用。

FSR有点像C语言中的指针,INDF是一个虚拟的寄存器,对它操作其实是对FSR锁指向的内存单元操作。

简单的说,当20h这个数赋给了FSR,那么就是FSR作为指针指向了内存中地址为20h的这个单元(以下就用<20h>来表示这个单元,以区别十六进制的20h这个数值),此时INDF就被映射到<20h>。

从头说起:

1:W被赋值20h这个数;2:FSR被赋值和W寄存器相同的数20H,此时FSR指向了<20h>;3:此时W寄存器因为没被改变过,所以其数值依然是十六进制的20h那么MOVWF 20H其实就是把W里的数据赋值给<20h>这个内存单元 也就是 <20h>= 20H;

4:重点来了 INCF INDF,让INDF自加1。前面说了对INDF操作其实就是对FSR所指向的单元操作,也就等同于 INCF <20h>(真正程序里不能这么写的,因为<20h>这杨写法是错误的) 类似C与语言中的<20h>++

5:FSR自加1,FSR内部的值等于21h所以FSR指向了<21h>这个内存单元。

6:<20h>单元的数值高4位和低4位转换一下数据。所以 <20h>= 02h

7:把<20h>的内容赋值给W寄存器,所以w = 02h

8:FSR此时 等于21h ,把21h和W的02h做与运算,结构 0 赋值给FSR。