查看原理图
在210中,外设的连接路线基本上是已经确定好的,哪个外设连接了哪些引脚,这些引脚对应的是哪个寄存器,都能在手册中找到,之后,通过操作对应的寄存器来实现对外设的控制。
我在学习51单片机的时候,LED的连接并没有确定,只知道LED的阳极引脚分别为JR1-JR8,引出在J12排针上。
LED的点亮比较容易,只要通电即可,此处是共阴极接地,那么,只要阳极接上高电平,就能点亮对应的LED。
查看数据手册
根据210的学习,通常是使用GPIO来控制LED的,不知道51是怎么控制的?
我自己去找相关的寄存器,并没有明确说哪些引脚是控制LED的。
理论上,连接任意的GPIO都可以。
本文将8个LED灯连接到了P0端口,同时,给锁存器的LE置高电平,让它工作在跟随状态。
实际中的开发板,不会让自己连线的,一般都是已经焊接好了。
端口操作方式
使用一款单片机或者芯片时,需要知道它是如何来操作IO端口的。
我在学习210时,是不同的寄存器控制着相应的端口,端口包含了若干个引脚。赋值时,是通过向寄存器地址所对应的内存中写入控制数据,比如:
*port0Reg = 0x1001F3F0
不过,在51中,虽然也是通过寄存器来控制,但是51单片机已经定义好了相应的端口,直接给端口赋值即可完成引脚控制。
51的端口和引脚定义就在reg51.h头文件中,所以写51代码时,需要引入该头文件。
51头文件reg51.h详解_路溪非溪的博客-CSDN博客
我的代码
功能1:点亮所有的LED,然后熄灭所有的LED,接着又点亮所有的LED。依次循环。
/**
*@author Timi
*@date 2022.07.13
*@version 1.0
*/
#include <reg51.h>
void LedFlash();
void delay();
void main(void)
{
LedFlash();
}
/**
*@brief 所有LED闪烁
*@param[in]
*@param[out]
*@return
*/
void LedFlash()
{
while(1)
{
P0 = 0XFF;
delay();
P0 = 0X00;
delay();
}
}
/**
*@brief 延时
*@param[in]
*@param[out]
*@return
*/
void delay()
{
int i = 0, j = 0;
for(i;i<30000;i++)
{
for(j;j<30000;j++);
}
}
功能2:点亮对应的LED灯。
/**
*@file bitlightled.c
*@author Timi
*@date 2022.07.13
*@version 1.0
*/
#include <reg51.h>
enum ledsNum
{
LED0, LED1, LED2, LED3, LED4, LED5, LED6, LED7
};
void BitLightLed(int ledNum);
void LedFlash();
void Delay();
//程序入口
void main(void)
{
BitLightLed(LED3);
}
/**
*@brief 指定LED点亮
*@param[in] LED的编号,0—7
*@param[out]
*@return
*/
void BitLightLed(int ledNum)
{
if(ledNum < 0 || ledNum >7)
{
LedFlash();
}
else
{
P0 = (0x1 << ledNum);
}
}
/**
*@brief 所有LED闪烁
*@param[in]
*@param[out]
*@return
*/
void LedFlash()
{
while(1)
{
P0 = 0XFF;
delay();
P0 = 0X00;
delay();
}
}
/**
*@brief 延时
*@param[in]
*@param[out]
*@return
*/
void Delay()
{
int i = 0, j = 0;
for(i;i<20000;i++)
{
for(j;j<20000;j++);
}
}
优化总结
|