微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 单片机双机通信(C51程序)

单片机双机通信(C51程序)

时间:10-31 来源:互联网 点击:

/*
发送程序
连线:两个单片机用3根线连起来,要共地,rxd,txd要交叉连接
程序效果:通过主机发送,从机接收
在主机中通过记下按键按下的次数,主机中显示最后
按下的六个数值,并发送给从机,从机也显示这六个数值
*/

#includereg52.h> //头文件
#includeintrins.h> //循环移位文件
#define uchar unsigned char//宏定义
#define uint unsigned int
sbit key1=P3^5; //位声明
uchar code table[]={0X00,0x3f,0x06,0x5b,//数码管显示的数值
0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar table_tr[6];//暂存最后按下的六个数值
uchar count,cnt;
//延时子函数,用于数码管显示
void delay(uchar i)
{
uchar x,y;
for(x=i;x>0;x--)
for(y=110;y>0;y--);
}
//初始化子函数
void init()
{
TMOD=0x20;//T1工作在方式2
TH1=0XF4;//波特率为4.8kbit/s
TL1=0XF4;
TR1=1;//启动定时器1
SCON=0X50;//串口工作在方式1,允许接收
}
//显示子函数
void display()
{
uchar i,j;//定义局部变量
j=0x7f; //赋初值
for(i=0;i6;i++)
{
P2=j; //点亮最右边的数码管
P0=table[table_tr[i]]; //显示该数值
delay(10); //延时,便于眼睛看清
j=_cror_(j,1);//循环右移一位
}
}
//按键扫描子函数
void key_scan()
{
if(key1==0) //判断是否有按键按下
{
while(!key1) //等待按键松手
{
display();//防止掉显
}
cnt++; //加1,用于显示
SBUF=cnt;//送给缓冲区,发送
while(!TI); //等待发送完
TI=0; //发送完了,标志位清零
for(count=0;count5;count++) //用于保存最后按下的六个按键数值
{
table_tr[count]=table_tr[count+1];
}
table_tr[5]=cnt; //把最后按下的按键数值赋给table_tr
if(cnt==10) //按键按下的次数有没有等于10
cnt=0;//等于,则清零
}
}
void main()
{
init(); //调用初始化子函数
P0=0x00;
while(1)
{
key_scan(); //调用键盘扫描子函数
display();//调用显示子函数
}
}

完整程序下载:http://www.51hei.com/ziliao/file/shuangjic.rar,
用keil c51编译通过,运行测试通过.


/*
接收程序
线路连接:同上, 主从单片机用3线连接,共地,rxd,txd交叉
程序效果:用于显示主机发送的数值
*/

#includereg52.h> //头文件
#includeintrins.h> //循环文件
#define uchar unsigned char//宏定义
#define uint unsigned int
uchar code table[]={0X00,0x3f,0x06,0x5b,//数码管显示的数值
0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar table_tr[6];//暂存最后按下的六个数值
uchar count,cnt;//定义全局变量
//延时子函数,用于数码管显示
void delay(uchar i)
{
uchar x,y;
for(x=i;x>0;x--)
for(y=110;y>0;y--);
}
//初始化子函数
void init()
{
TMOD=0x20;//T1工作在方式2
TH1=0XF4; //波特率为:4.8kbit/s,发送与接收的波特率要相等
TL1=0XF4;
TR1=1; //启动定时器1
SCON=0X50;//串口中断工作在方式1,允许接收
}
//显示子函数
void display()
{
uchar i,j;//定义局部变量
j=0x7f; //赋值
for(i=0;i6;i++) //显示六个数值
{
P2=j;
P0=table[table_tr[i]];
delay(10);
j=_cror_(j,1);//循环右移一位
}
}
//主函数
void main()
{
uchar i;//定义局部变量
init(); //调用初始化子函数
while(1)
{
while(RI) //判断是否接受完
{
RI=0;//接受完了,标志位清零
for(i=0;i5;i++) //把数组的数值都往前移一位,腾出table_tr
table_tr[i]=table_tr[i+1];
table_tr[5]=SBUF;//装入接收的数值
}
display();//调用显示子函数
}
}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top