【51单片机】:串口通信控制LED亮灭任务

文章介绍了如何使用51单片机通过串口通信控制LED灯的开关。通过两种方法实现,一是使用数组逐字符判断,二是利用C语言的strncmp函数进行字符串匹配。串口通信助手发送on和off字符串,单片机接收到后相应地开启或关闭LED,并将接收到的命令回传给串口助手。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

学习目标:

        使用51单片机的串口通信,当串口通信助手

                发送字符串  on  led开启   

                发送字符串  off  led关闭

并且串口助手实时返回   发送的字符串


学习内容(代码):

        第一种方法,使用数组依次判断接收到的字符串,根据判断的结果来使能led灯,并持续发送到串口助手上。


#include "reg52.h"
#include "string.h"

typedef unsigned int u16;	//对系统默认数据类型进行重定义
typedef unsigned char u8;


/*******************************************************************************
* 函 数 名       : uart_init
* 函数功能		 : 串口通信中断配置函数,通过设置TH和TL即可确定定时时间
* 输    入       : baud:波特率对应的TH、TL装载值
* 输    出    	 : 无
*******************************************************************************/
void uart_init(u8 baud)
{
	TMOD|=0X20;	//设置计数器工作方式2
	SCON=0X50;	//设置为工作方式1
	PCON=0X80;	//波特率加倍
	TH1=baud;	//计数器初始值设置
	TL1=baud;
	ES=1;		//打开接收中断
	EA=1;		//打开总中断
	TR1=1;		//打开计数器		
}

/*******************************************************************************
* 函 数 名       : main
* 函数功能		 : 主函数
* 输    入       : 无
* 输    出    	 : 无
*******************************************************************************/
u8 rec_data[6];
void main()
{	
	uart_init(0XFA);//波特率为9600
	while(1)
	{			
		if((rec_data[0] == 'o') && (rec_data[1] == 'n')){
			P2 = 0x00;
		}else if((rec_data[0] == 'o') && (rec_data[1] == 'f') && (rec_data[2] == 'f')){
			P2 = 0xff;
		}		
	}		
}

int i =0 ;
void uart() interrupt 4 //串口通信中断函数
{
	RI = 0;			//清除接收中断标志位
	if(SBUF != '\n')
	{
		rec_data[i]=SBUF;	//存储接收到的数据
		SBUF = rec_data[i];
		while(!TI);
		TI = 0;
		i++;
	}	
	else
		i = 0;
}


串口助手返回:

视频效果:

51单片机串口通信控制led亮灭

项目链接:(10条消息) 51单片机的串口通信控制板载led亮灭资源-CSDN文库


学习内容:

        利用c语言的字符串匹配方法解决问题。

C 库函数 int strncmp(const char *str1, const char *str2, size_t n) 把 str1 和 str2 进行比较,最多比较前 n 个字节。

参数

  • str1 -- 要进行比较的第一个字符串。
  • str2 -- 要进行比较的第二个字符串。
  • n -- 要比较的最大字符数。

返回值

该函数返回值如下:

  • 如果返回值 < 0,则表示 str1 小于 str2。
  • 如果返回值 > 0,则表示 str1 大于 str2。
  • 如果返回值 = 0,则表示 str1 等于 str2。

#include "reg52.h"
#include "string.h"

typedef unsigned int u16;	//对系统默认数据类型进行重定义
typedef unsigned char u8;


/*******************************************************************************
* 函 数 名       : uart_init
* 函数功能		 : 串口通信中断配置函数,通过设置TH和TL即可确定定时时间
* 输    入       : baud:波特率对应的TH、TL装载值
* 输    出    	 : 无
*******************************************************************************/
void uart_init(u8 baud)
{
	TMOD|=0X20;	//设置计数器工作方式2
	SCON=0X50;	//设置为工作方式1
	PCON=0X80;	//波特率加倍
	TH1=baud;	//计数器初始值设置
	TL1=baud;
	ES=1;		//打开接收中断
	EA=1;		//打开总中断
	TR1=1;		//打开计数器		
}

/*******************************************************************************
* 函 数 名       : main
* 函数功能		 : 主函数
* 输    入       : 无
* 输    出    	 : 无
*******************************************************************************/
u8 rec_data[6];
void main()
{	
	uart_init(0XFA);//波特率为9600
	while(1)
	{			
		if(strncmp(rec_data,"on",2)==0){
			P2=0X00;
		}else if(strncmp(rec_data,"off",3)==0){
			P2=0XFF;
		}		
	}		
}

int i =0 ;
void uart() interrupt 4 //串口通信中断函数
{
	RI = 0;			//清除接收中断标志位
	if(SBUF != '\n')
	{
		rec_data[i]=SBUF;	//存储接收到的数据
		SBUF = rec_data[i];
		while(!TI);
		TI = 0;
		i++;
	}	
	else
		i = 0;
}


效果如上个一样,不再展示。


梦回大唐

在C51单片机中,要控制LED和蜂鸣器的响停,通常会用到以下几个步骤: 1. **初始化硬件**:首先需要配置I/O口为输出模式,以便驱动LED和设置蜂鸣器的工作状态。例如,如果LED连接到P0口,蜂鸣器连接到P3口,那么要将它们设为输出。 ```c #include <reg52.h> sbit LED = P0^0; // LED引脚定义为P0口第0位 sbit Buzzer = P3^0; // 蜂鸣器引脚定义为P3口第0位 void init_GPIO(void) { P0 = 0; // 清零P0口,初始所有LED关闭 P3 |= 0x01; // 设置P3口第0位为输入,用于蜂鸣器控制 } ``` 2. **处理字符串操作**:对于字符控制,你可以编写函数来接收字符串,并遍历每个字符。如果是'0'/'1'这样的ASCII码表示的开/关,可以转换为数字来控制LED;如果是特定的字符(比如'!'表示蜂鸣器响),则通过写入高低电平来触发蜂鸣器。 ```c void control_LED_Buzzer(char* str) { while (*str != '\0') { // 遍历字符串直到遇到结束符 if (*str == '0' || *str == '1') { LED = (*str - '0'); // 根据字符调整LED状态 } else if (*str == '!') { Buzzer = !Buzzer; // 判断是否应该响铃 } str++; } } ``` 3. **主循环和定时控制**:在主程序的无限循环中调用这个函数,并可能加入定时器来增加动态效果,如闪烁LED或间隔性地触发蜂鸣器。 ```c void main(void) { init_GPIO(); char cmd[] = "101!0111"; // 示例字符串 control_LED_Buzzer(cmd); while (1); // 无条件等待 } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式up

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值