#include <reg51.h>
#include <absacc.h>
#define TR 1
#define uchar unsigned char
#define uint unsigned int
uchar idata buf[10]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09}; //从机1发送的数据
uchar idata buf1[10]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x08,0x09}; //从机2发送的数据
uchar idata buf2[3]; //接受从机的数据
uchar data1,data2,data3;
uchar pf,addr,TRR,count,count1;
uchar flag,flag1,flag2=3;
uchar i;
sbit key1=P2^0;
/************延时程序************/
void delay(uchar k)
{
uchar j;
while((k--)!=0)
{
for(j=0;j<125;j++)
{;}
}
}
void init(void)
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
PCON=0x00;
TR1=1;
SCON=0xd0;
}
void send(uchar addr,uchar TRR)
{
TB8=1;
key1=1; //TB8置1
SBUF=addr; //发送从机的地址
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0)
{
;
}
data1=SBUF; //接受从机地址并检验
RI=0;
if(data1!=addr) //从机地址有错误
{
flag2=0;
}
else{ //从机地址正确--------是发送数据标志0X01
if(TRR==0x01)
{
TB8=0; //TB8置0
key1=1;
SBUF=TRR;
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //接受从机状态
{
;
}
data3=SBUF;
RI=0;
if(data3!=TRR) //从机没有就绪
{
flag2=0;
}
else{ //从机就绪
pf=0; //清效验位
key1=1;
for(i=0;i<=9;i++) //发送数据
{
TB8=0;
SBUF=buf[i];
pf+=buf[i];
while(TI==0)
{
;
}
TI=0;
}
TB8=0;
SBUF=pf; //发送效验和
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //主机接受从机是否正确接受数据
{
;
}
data2=SBUF;
RI=0;
if(data2==0xcc) //如果正确结束数据通信
{
flag2=3; //通信结束标志
}
else{
flag2=0; //如果不正确重新通信------即重新通信标志
}
}
}
if(TRR==0x02)
{ //是接受从机数据标志------即TRR=0X0
TB8=0;
key1=1;
SBUF=TRR; //发送接受标志0X02
while(TI==0)
{
;
}
TI=0;
key1=0;
while(RI==0) //接受从机的状态
{
;
}
data3=SBUF;
RI=0;
if(data3!=TRR) //从机没有就绪
{
flag2=0;
}
else{ key1=0; //从机就绪---主机接受数据
pf=0;
for(i=0;i<=2;i++)
{
while(RI==0)
{
;
}
buf2[i]=SBUF; //接受从机发送的数据
pf+=buf2[i];
RI=0;
}
key1=0;
while(RI==0) //接受从机的效验和
{
;
}
data2=SBUF;
RI=0;
if(pf==data2) //比较效验和
{
flag2=3; //效验和正确标志
}
else{
flag2=0; //效验和错误标志
}
}
}
}
}
void display(void)
{
if(flag2==3) //如果接受正确开始显示
{
for(i=0;i<=2;i++)
{
P0=buf2[i];
delay(50);
}
}
}
void main(void)
{
delay(500);
init();
count=2;
count1=2;
while(1)
{
while(count!=0)
{
count--;
send(0x03,0x01); //主机---从机1交换数据子函数
send(0x03,0x02);
display();
}
while(count1!=0)
{ count1--;
send(0x04,0x01); //主机---从机1交换数据子函数
send(0x04,0x02);
display();
}
if(count1==0)
{
count1=2;
count=2;
}
}
}
![avatar](https://profile-avatar.csdnimg.cn/default.jpg!1)
荣华富贵8
- 粉丝: 225
- 资源: 7653
最新资源
- 虚拟同步发电机SG的离并网预同步切换技术及其自适应与转动惯量控制策略研究,虚拟同步发电机SG离并网切换与自适应转动惯量控制策略研究,虛拟同步发电机SG离并网(预同步)切与自适应 转动惯量控制策略 ,虚
- 全球海洋酸化趋势和影响-Global Ocean Acidification Trends and Impacts dataset
- 大学校园网充值系统新版源码+说明
- 2023全新仿短视影视模版源码 PC+H5自适应 明暗双皮肤 苹果CMS系统
- 基于vue的高标准农田项目新版源码+说明-遥感监测-AI识别-地物分类
- 基于 FPGA 的农业温室大棚监测控制系统资料
- CO₂排放量的逐年变化(1751年至2023年)-Year-on-Year change in CO₂ emission (1751 to 2023)
- 163类中药材图像分类数据集【已标注,约100,000张数据】
- 基于智能开发套件的智能农业灌溉系统联动场景开发方案
- 基于 EfficientNet v2轻量级网络实现的图像识别实战:163种中药材识别
- 弱智吧问答对内容,包含千条json问答
- 基于物联网的智慧农业温室暖棚控制与监测系统软硬件方案+说明+资料
- 《基于多源数据的区域综合能源系统热网模型构建及优化运行策略分析》,多区域综合能源系统热网建模与优化运行策略:基于实证研究与数据分析,多区域综合能源系统热网建模及系统运行优化 有参考文献,有数据 ,核心
- IMDB Movies From 1960 to 2024 dataset 数据集
- 基于改进GOSO ISO算法优化BP神经网络数据回归预测的实践与应用研究:混沌映射、减法优化器与反向学习策略的深度探索,GOSO ISO-BP神经网络:改进蛇优化算法与BP神经网络的融合及数据回归预测
- RAIN Dataset -雨水数据集-单幅图像去雨算法
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback-tip](https://img-home.csdnimg.cn/images/20220527035111.png)