MCS-51单片机控制跑马灯的三种方法

控制/MCU

1813人已加入

描述

  在MCS一51单片机的控制系统中,它的四个并行8位输入输出端口P0一P3是我们经常使用的。在并行端口的编程学习中,“跑马灯”是单片机并行端口输出控制的典型实例。所谓跑马灯,是指将八个发光二极管分别连接到单片机的某一并行端口的八根线上,通过编程控制这八个发光二极管从低到高或从高到低依次点亮。

  单片机

  图1   跑马灯电路图

  如图1所示,将8个发光二极管阴极接到MCS一51单片机P1端口的8根端口线上,阳极通过限流电阻接+5V电源。要让发光二极管点亮,则对应的端口线应该为低电平(‘’0’);而要让其熄灭,对应的端I=I线应该为高电平(“1”)。由此,我们假定“跑马灯”由端I=1的低位向高位轮流点亮.可以得到如下状态:

  表1   跑马灯状态表

单片机

  从表1可以看出,P1端口的状态共有8种,在“跑马灯”的显示过程中.这8种状态依次出现,循环往复。而要实现“跑马灯”的这种 显示功能.我们可以采用三种方法:

  (1)穷举法;

  (2)移位法;

  (3)查表法。

  下面分别来介绍一下这三种方法。

  一、穷举法

  对于单片机的显示状态来说,它的8种状态是循环显示的。所谓穷举法。是指将单片机所有的显示状态全部列举出来。写在程序的主函数中,通过while(1)的死循环来实现这些状态的循环显示。

  程序如下:

 #include<reg51.h> //延时函数.延时0.5s

  voiddelay()

  {

  单片机

  通过上述程序可以看出,穷举法程序结构简单。直接将所有需要的状态在主函数中全部列举出来即可。

  二、移位法

  通过观察表一中列出的跑马灯8种状态,从0FEH变化到7FH。这些状态从二进制来看,始终是保持7个“1”,1个“0”;并且“0”的位置从最低位依次移动到最高位,每次向左移动一位。当‘0’移动到最高位后,又重新从最低位开始。

  在C语言中,我们学习过位操作运算符。在位操作运算符中,有专门的二进制移位运算符。其中,“<<”运算符表示将二进制数左移, “>>”运算符表示将二进制数右移。不管是左移还是右移,移出来的空位补0。但是,我们观察跑马灯的8种状态可以看出,在“0’向左移动的过程中,移位空出来的状态是补1,这样保证始终是7个“1”,1个“0”。所以,在这里直接对最终显示的状态进行左移操作显然是不行的。由此,我们考虑将初始数据变成7个“0”,1个”1”,对初始数据进行左移,左移之后再取反,即可变成7个“1”,1个“0”的显示状态,从而实现跑马灯功能。如表2所示。

  比较表1和表2的状态.可以看出采用先对初始状态移位再取反的方式.可以得到想要的跑马灯8种状态,从而实现跑马灯的显示。

  程序如下:

  #include<reg51.h>

  void delay0

  { unsigned char i,j,k; //延时函数.延时0.5s

  for(i_5;i>0;i-一)

  for 0=200;j>O;j--)

  for(k=250;k>0;k--);

  }

  单片机

  通过上述程序可以看出.移位法通过对二进制数进行移位之后再取反的方式来得到跑马灯的状态,并将其送端口实现跑马灯的显示。

  三、查表法

  所谓“查表”,指的是将程序中需要用到的所有数据建立成一个表格,再在程序中依次访问每一个表格数据。在C语言中,我们可以在程序开始位置将表格定义成一个数组。然后在程序中,通过循环结构程序依次访问表格数组的每一个元素(即查表)。

  表2移位法实现跑马灯的状态表

  单片机

  通过表一,我们知道跑马灯的显示状态有8种,那么我们可以将这8种状态建立成一个8个元素的数组,再通过循环结构查表,依次将每一个元素送给端口显示。

  程序如下:

  单片机

  单片机

  通过上述程序可以看出,查表法将跑马灯的所有数据在程序开始定义成一个数组,然后在主函数main()中用一个for循环依次访问每一个数组元素。实现查表。

  四、三种实现方法的比较

  穷举法、移位法、查表法都可以实现单片机“跑马灯”的显示控制。

  穷举法,顾名思义,这种方法要将所有的状态在程序中一列举出来,不管这些数据是有规律的还是无规律的。从穷举法的程序我 们可以看出,它的程序结构在三种方法中是最简单的。但是,穷举法 列举的状态越多,程序就越长。所以,穷举法比较适合于数据或状态较少的场合。

  移位法,是采用二进制数的移位操作来实现数据的显示。我们观察表一和表二的跑马灯状态可以看出:在跑马灯中.它的每一个状态都可以通过在上一个状态的基础上移位、取反来得到。其数据的变化是有规律的。所以,移位法适合于数据呈规律变化。下一个数据可由上一个数据通过计算来得到的场合,klan:“跑马灯”,以及单片机的动态扫描控制等。

  查表法,是将所有数据在程序开始定义成一个表格。再通过循环 结构程序依次访问每一个数据来实现查表。观察查表法程序的数据,我们可以看出,所有数据都定义成了一个数组,而数组中的数据是不是有规律,对查表法没有什么影响。所以。查表法中既可以使用有规律的数据,也可以使用无规律的数据。查表法的程序比穷举法精干,使用的数据不需要像移位法要求的规律.所以在单片机的程序设计中,查表法得到了广泛的应用。比如:数码管的显示控制、LED点阵的显示控制等。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分