1 / 9
文档名称:

移位知识 移位运算.doc

格式:doc   大小:168KB   页数:9页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

移位知识 移位运算.doc

上传人:cby201601 2020/5/28 文件大小:168 KB

下载得到文件列表

移位知识 移位运算.doc

相关文档

文档介绍

文档介绍:AVR移位算法详细解释(1<<X)很多初学者都会被移位算法迷惑,移位算法形如(1<<X)这样的形式,高手写程序时****惯用移位算法来写出各个寄存器的使用。比如下面一段是AVR的USART的初始化代码。UCSRC=(1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);UCSR0B=(1<<RXCIE)|(1<<TXCIE)|(1<<RXEN)|(1<<TXEN);//RXCIE=1;TXCIE=1;UDREIE=0;RXEN=1;TXEN=1这样的写法对高手是福,这些代码里面说明了操作了寄存器的哪些位,能够看出它的操作的意义;对新手确是祸害,因为新手看不懂这样的程序。回到开始的地方,解释一下,什么是移位算法:如:A=(1<<2),1写成二进制就是00000001,这个一左移2位就是00000100,所以得到的数A为00000100,即0x04。再如:B=(2<<4),2写成二进制就是00000010,这个一左移4位就是00100000,所以得到的数B为00100000,即0x20。上面两个移位算法都是正确的,第一种写法,表示第三位为1其余都是0的数,数的时候是从0数起的,再比如(1<<0)表示的是00000001,(1<<7)表示的是10000000,但是第二种写法没有没有这种意义,移位也用于乘除法,左移一位乘以2,右移移位除以2,上面的第二种写法2左移四位得到的数是2×2×2×2×2=32,也就是上面的0x20。我们再来看上面的这句话:UCSRC=(1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);UCSRC是一个和串口通讯有关的一个八位寄存器,他的每一位都有特殊的定义,我们通过查数据手册可以看到,如下的内容。#defineURSEL7这样的定义,1<<URSEL即是wei7,1<<UCSZ1选择位2,1<<UCSZ0选择位1,整句话UCSRC=(1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);的效果就是让UCSRC的位七,位二,位一为高,其他都为低,然后在数据手册里面你可以看到各个位的作用。UCSRC=(1<<7)|(1<<2)|(1<<1)即UCSRC=10000110单片机入门系列--MEGA端口操作说明:本节重点介绍真正双向端口操作的方法,及与伪双向端口操作的不同。跑马灯例子。建议先看跑马灯,再绕回来看前面的介绍。 AVR端口是真正的双向端口,不像51伪双向。这也是AVR的一项优势,只是操作时大家注意DDRn就可以了。真正双向端口在模拟时序方面不如伪双向的方便。 DDRnPORTnPINn解释:n为端口号:ABCDE DDRn:控制端口是输入还是输出,0为输入,1为输出。个人记忆方法:一比零大所以往外挤,即1为输出,0为输入。 PORTn:从引脚输出信号,当DDRn为1时,可以通过PORTn=x等端口操作语句给引脚输出赋值。 PINn:从引脚读输入信号,无论DDRn为何值,都可以通过x=PINn获得端口n的外部电平。 当引脚配置为输入时,若PORTxn为"1“,上拉电阻将使能。内部上拉电阻的使用在键盘扫描的时候还要说到。端口更详细功能及介绍以及端口第二功能请参考数据手册。端口引脚配置DDxn PORTxn PUD(inSFIOR) I/O 上拉电阻说