两个51单片机串口通信,要求甲单片机的按键控制乙单片机的两个LED,按一下亮一个,再按一下切换到另一个LED;乙单片机按键计数显示在甲单片机连接的数码管上

时间: 2024-03-14 15:42:45 浏览: 47
下面是甲单片机和乙单片机的代码实现。甲单片机通过串口向乙单片机发送指令,控制乙单片机的LED灯亮灭状态。乙单片机通过计数器计算按键按下的次数,并将结果通过串口发送给甲单片机,甲单片机再将计数结果显示到连接的数码管上。 甲单片机代码: ```c #include <reg51.h> #define uchar unsigned char #define uint unsigned int sbit LED1 = P1^0; sbit LED2 = P1^1; sbit Key = P3^4; //按键接在P3.4口 void InitUART(); void UARTSend(uchar dat); void UARTSendStr(uchar *str); void delay(uint z); void main() { uchar cnt = 0; //按键计数 uchar flag = 0; //LED灯状态标志 uchar recvData = 0; //接收到的数据 InitUART(); while(1) { if(Key == 0) //按键按下 { delay(10); //消除抖动 if(Key == 0) //确保按键稳定按下 { cnt++; //计数器加1 if(cnt > 2) cnt = 1; //计数器取值范围为1~2 if(cnt == 1) { flag = 0; //LED1亮,LED2灭 UARTSend('1'); //向乙单片机发送指令,控制LED1亮 } else if(cnt == 2) { flag = 1; //LED2亮,LED1灭 UARTSend('2'); //向乙单片机发送指令,控制LED2亮 } while(Key == 0); //等待按键释放 } } if(RI) //接收到数据 { RI = 0; //清除接收中断标志 recvData = SBUF; //读取接收到的数据 if(recvData == 'C') //接收到乙单片机的计数数据 { recvData = SBUF; //读取计数数据 P0 = recvData; //显示计数数据到数码管 } } } } void InitUART() { SCON = 0x50; //设置为8位数据位,无校验位,1位停止位,允许接收 TMOD &= 0x0F; //设置为定时器1工作方式1 TMOD |= 0x20; TH1 = 0xFD; //设置波特率为9600 TL1 = 0xFD; TR1 = 1; //启动定时器1 ES = 1; //允许串口中断 EA = 1; //开启总中断 } void UARTSend(uchar dat) { SBUF = dat; //将数据写入发送缓存 while(!TI); //等待发送完成 TI = 0; //清除发送中断标志 } void UARTSendStr(uchar *str) { while(*str) { UARTSend(*str++); } } void delay(uint z) { uint x,y; for(x = z;x > 0;x--) for(y = 110;y > 0;y--); } void UARTInterrupt() interrupt 4 { if(RI) //接收中断 { RI = 0; //清除接收中断标志 } if(TI) //发送中断 { TI = 0; //清除发送中断标志 } } ``` 乙单片机代码: ```c #include <reg51.h> #define uchar unsigned char #define uint unsigned int sbit LED1 = P1^0; sbit LED2 = P1^1; sbit Key = P3^4; //按键接在P3.4口 void InitUART(); void UARTSend(uchar dat); void UARTSendStr(uchar *str); void delay(uint z); void main() { uchar cnt = 0; //按键计数 uchar sendData = 0; //发送的数据 InitUART(); while(1) { if(Key == 0) //按键按下 { delay(10); //消除抖动 if(Key == 0) //确保按键稳定按下 { cnt++; //计数器加1 if(cnt > 2) cnt = 1; //计数器取值范围为1~2 if(cnt == 1) { LED1 = 1; //LED1亮,LED2灭 LED2 = 0; } else if(cnt == 2) { LED1 = 0; //LED2亮,LED1灭 LED2 = 1; } while(Key == 0); //等待按键释放 } } sendData = cnt + '0'; //将计数器转换为字符形式,用于发送 UARTSend('C'); //发送计数数据标志 UARTSend(sendData); //发送计数数据 delay(100); //延时一段时间,避免频繁发送数据 } } void InitUART() { SCON = 0x50; //设置为8位数据位,无校验位,1位停止位,允许接收 TMOD &= 0x0F; //设置为定时器1工作方式1 TMOD |= 0x20; TH1 = 0xFD; //设置波特率为9600 TL1 = 0xFD; TR1 = 1; //启动定时器1 ES = 1; //允许串口中断 EA = 1; //开启总中断 } void UARTSend(uchar dat) { SBUF = dat; //将数据写入发送缓存 while(!TI); //等待发送完成 TI = 0; //清除发送中断标志 } void UARTSendStr(uchar *str) { while(*str) { UARTSend(*str++); } } void delay(uint z) { uint x,y; for(x = z;x > 0;x--) for(y = 110;y > 0;y--); } void UARTInterrupt() interrupt 4 { if(RI) //接收中断 { RI = 0; //清除接收中断标志 } if(TI) //发送中断 { TI = 0; //清除发送中断标志 } } ``` 需要注意的是,甲单片机和乙单片机之间的串口通信需要使用相同的波特率、数据位、校验位和停止位,以确保数据的正确传输。另外,在发送数据时需要注意数据的类型和范围,以免出现数据溢出或错误。

相关推荐

最新推荐

recommend-type

51单片机脉冲宽度调制(PWM)控制LED灯亮度

绍一个51系列单片机采用脉冲宽度调制(PWM)方式控制LED灯亮度的一个程序,大家都知道,51单片机本身是没有pwm接口的,这个程序是通过软件模拟pwm.在一定的频率的方波中,调整高电平和低电平的占空比,即可实现LED灯...
recommend-type

51单片机串口通信的发送与接收

51单片机的串口,是个全双工的串口,发送数据的同时,还可以接收数据。当串行发送完毕后,将在标志位 TI 置 1,同样,当收到了数据后,也会在 RI置 1。无论 RI 或 TI 出现了 1,只要串口中断处于开放状态,单片机...
recommend-type

单片机C51串口中断接收和发送测试例程(含通信协议的实现)

这是一个单片机C51串口接收(中断)和发送例程,可以用来测试51单片机的中断接收和查询发送,另外我觉得发送没有必要用中断,因为程序的开销是一样的
recommend-type

51单片机(AT89C52)一键多功能(短按、长按)

短按(按下持续时间小于3s)一次数码管显示加1,同时流水灯计数加1。长按(按下持续时间大于3s)时,数码管显示每500ms加1,同时流水灯每500ms计数加1。
recommend-type

51单片机驱动16×16LED点阵显示动画汉字汇编程序

这里提供一个完整的AT89S51单片机驱动驱动led点阵显示具有动画效果的汉字的汇编程序列子。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】增量式PID的simulink仿真实现

# 2.1 Simulink仿真环境简介 Simulink是MATLAB中用于建模、仿真和分析动态系统的图形化环境。它提供了一个直观的用户界面,允许用户使用块和连接线来创建系统模型。Simulink模型由以下元素组成: - **子系统:**将复杂系统分解成更小的、可管理的模块。 - **块:**代表系统中的组件,如传感器、执行器和控制器。 - **连接线:**表示信号在块之间的流动。 Simulink仿真环境提供了广泛的块库,涵盖了各种工程学科,包括控制系统、电子和机械工程。它还支持用户自定义块的创建,以满足特定仿真需求。 # 2. Simulink仿真环境的搭建和建模 ### 2.
recommend-type

训练集和测试集的准确率都99%,但是预测效果不好

即使训练集和测试集的准确率都很高,但是在实际的预测中表现不佳,可能会有以下几个原因: 1. 数据质量问题:模型训练和测试的数据可能存在问题,比如数据标签错误、数据集采样不均衡、数据集中存在异常值等问题,这些问题可能会导致模型在实际预测中表现不佳。 2. 特征工程问题:模型的特征工程可能存在问题,导致模型无法很好地捕捉数据的特征,从而影响预测效果。 3. 模型选择问题:模型的选择可能不合适,比如选择的模型太简单,无法很好地拟合数据,或者选择的模型太复杂,导致过拟合等问题。 4. 超参数调整问题:模型的超参数可能没有调整到最佳状态,需要进行调整。 针对以上可能的原因,可以采取相应的措施进
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。