⑴ 51單片機雙機通訊物理接線有什麼要求(晶元引腳怎麼連接)
51單片機雙機通訊,如果雙機距離超過了1米,就要採用RS232介面,這是常用的串口通信方式,物理接線可採用3線連接即可,距離超過10米時應採用雙芯屏蔽線。距離小於1米時,屬於實驗性的臨時串口通信,兩個單片機的RXD,TXD引腳交叉連接就行,需要共地,用普通的3條導線連接。
⑵ 51單片機怎麼雙機通信
你好!!
單片機雙機通訊,就是直接單片機的串口RX和TX直接連接,然後通過串口命令完成通訊!
給你一個實例,可以完全滿足你的要求!
希望幫到你,滿意請採納!
⑶ 51單片機雙機通訊問題
#include<reg51.h> //發送 供參考
sbitk0=P1^0; //這是10按鍵
sbitk1=P1^1; //發送0-9 的編碼
sbitk2=P1^2;
sbitk3=P1^3;
sbitk4=P1^4;
sbitk5=P1^5;
sbitk6=P1^6;
sbitk7=P1^7;
sbitk8=P3^3;
sbitk9=P3^4;
sbitled=P3^5;
bit y0,y1,y2,y3,y4,y5,y6,y7,y8,y9;
voidmain(void)
{
SCON=0x50; //REN=1允許串列接受狀態,串口工作模式1
TMOD|=0x20; //定時器工作方式2
PCON|=0x80; //數據位8、停止位1。效驗位無(12M)
TH1=0xFD; //TH1=0xFD;波特率9600
TL1=0xFD;
TR1 =1;
while(1)
{
if(k0==0&&y0==0){y0=1;SBUF=0xc0;led=0;}
if(k0==1){y0=0;}
if(k1==0&&y1==0){y1=1;SBUF=0xf9;led=0;}
if(k1==1){y1=0;}
if(k2==0&&y2==0){y2=1;SBUF=0xa4;led=0;}
if(k2==1){y2=0;}
if(k3==0&&y3==0){y3=1;SBUF=0xb0;led=0;}
if(k3==1){y3=0;}
if(k4==0&&y4==0){y4=1;SBUF=0x99;led=0;}
if(k4==1){y4=0;}
if(k5==0&&y5==0){y5=1;SBUF=0x92;led=0;}
if(k5==1){y5=0;}
if(k6==0&&y6==0){y6=1;SBUF=0x82;led=0;}
if(k6==1){y6=0;}
if(k7==0&&y7==0){y7=1;SBUF=0xf8;led=0;}
if(k7==1){y7=0;}
if(k8==0&&y8==0){y8=1;SBUF=0x80;led=0;}
if(k8==1){y8=0;}
if(k9==0&&y9==0){y9=1;SBUF=0x90;led=0;}
if(k9==1){y9=0;}
if(led==0)
{
while(!TI);
TI=0;
led=1;
}
}
}
#include<reg51.h>//接收
voidmain(void)
{
SCON=0x50; //REN=1允許串列接受狀態,串口工作模式1
TMOD|=0x20; //定時器工作方式2
PCON|=0x80; //數據位8、停止位1。效驗位無(12M)
TH1=0xFD; //TH1=0xFD;波特率9600
TL1=0xFD;
TR1 =1;
ES =1; //開串口中斷
EA =1; //開總中斷
P1=0xbf;
while(1)
{
}
}
voidchuankou(void)interrupt4
{
if(RI==1)
{
RI=0;
TI=0;
P1=SBUF; // 顯示0-9
}
}
⑷ 51單片機雙機串列通信時能使用接在P3.0/RXD,P3.1/TXD 上的獨立按鍵嗎
51單片機雙機串列通信時,必須專用P3.0/RXD,P3.1/TXD ,這兩個引腳上不允許有獨立按鍵的,否則會影響通信。
如果引腳實在不夠用,就要控制好使用順序,在用TXD腳上的按鍵時,就不能發送數據了。而RXD上最好不要有按鍵,因為不知道什麼時候串口有數據接收,在按鍵的同時,恰好有數據,就無法接收了。
⑸ 51單片機雙機通信
//=====================================================================
// 多機通訊主機程序
//zhuji.c
//writer:穀雨 2008年3月22日於EDA實驗室
//註:主機先發送地址,接收到應答後,再發送數據
//=====================================================================#include<reg52.h>#define addr1 0x31 //從機1地址
#define addr2 0x32 //從機2地址unsigned char xx[10];
unsigned char p = 0;void delay_1ms(unsigned int i)
{
unsigned char j;
while ((i--)!=0) {for (j=0;j<125;j++);}
}
void Uart_Init(void)
{
TMOD = 0x20; //定時器T1使用工作方式2
TH1 = 0XF3; TL1 = 0XF3; PCON = 0x00; //SMOD=1;
SCON = 0xf0; //工作方式3,9位數據位,波特率9600bit/s,允許接收
SM2 = 0;
TR1 = 1; //開始計時
EA = 1; //中斷允許
ES = 1; //串列中斷允許}
void Serial_INT() interrupt 4
{
if(!RI) return; ES = 0;
RI = 0;
xx[p] = SBUF;
p++;
ES = 1;
}
void send_addr(unsigned char addr) //發送地址
{
p = 0;
TB8 = 1; //發送地址幀
SBUF=addr; //發送地址
while(!TI); //等待發送完畢
TI=0; //軟體復位TI
}
void send_data(unsigned char ddata) //發送數據
{
TB8=0; //發送數據幀
SBUF=ddata; //發送數據
while(!TI);
TI=0; //軟體復位TI
}void main()
{
Uart_Init();
delay_1ms(2000);
while(1)
{
send_addr(addr1); //向從機1發地址
send_data(0x33);
send_data(0x01); delay_1ms(500);
if(xx[9]=='0') P1=0xaa; delay_1ms(500); send_addr(addr2); //向從機2發地址
send_data(0x33);
send_data(0x01); delay_1ms(500);
if(xx[9]=='9') P1=0x55; delay_1ms(500);
}
// while(1);
} //=====================================================================
// 多機通訊從機1程序
//cong1.c
//writer:穀雨 2008年3月22日於EDA實驗室
//註:
//=====================================================================
#include<reg52.h>
#define addr 0x31 //從機1地址unsigned char receive;
unsigned char xx[ ]={"1234567890"};void Uart_Init(void)
{
TMOD = 0x20; //定時器T1使用工作方式2
TH1 = 0XF3; TL1 = 0XF3; PCON = 0x00; //SMOD=1;
SCON = 0xf0; //工作方式3,9位數據位,波特率9600bit/s,允許接收 TR1 = 1; //開始計時
EA = 1; //中斷允許
ES = 1; //串列中斷允許}void Serial_INT() interrupt 4
{
if(!RI) return;
RI=0;
if(RB8==1)
{
if(SBUF==addr) SM2=0;
else SM2=1;
}
if(RB8==0) receive=SBUF;
}void SendOneByte(unsigned char c)
{
TB8=0;
SBUF = c;
while(!TI);
TI = 0;
}
void SendListChar(unsigned char *DData,unsigned char Ef)
{
unsigned char L=0; if(Ef!=0)
{
for( ;L<Ef;L++) //顯示有效長度
SendOneByte(DData[L]); //發送單個字元
}else
while (DData[L]!='\0') //發送至字串結束
{
SendOneByte(DData[L]); //發送單個字元
L++; //下一個字元
}
}void main()
{
Uart_Init();
while(1)
{
switch(receive)
{
case 0xff:
break;
case 0x01: //在此可以寫入要完成的動作,最多可完成256個動作
SendListChar(xx,0);
break;
case 0x02:
break;
case 0x33:
P1=!P1; //為方便其間,賦值給P1口,測P1口電平來檢測該程序
break;
default:
break;
}
receive=0xff;
}
}
⑹ 51單片機雙機通信問題
#include<reg51.h> //發送 供參考
sbitk0=P1^0; //這是10按鍵
sbitk1=P1^1; //發送0-9 的編碼
sbitk2=P1^2;
sbitk3=P1^3;
sbitk4=P1^4;
sbitk5=P1^5;
sbitk6=P1^6;
sbitk7=P1^7;
sbitk8=P3^3;
sbitk9=P3^4;
sbitled=P3^5;
bit y0,y1,y2,y3,y4,y5,y6,y7,y8,y9;
voidmain(void)
{
SCON=0x50; //REN=1允許串列接受狀態,串口工作模式1
TMOD|=0x20; //定時器工作方式2
PCON|=0x80; //數據位8、停止位1。效驗位無(12M)
TH1=0xFD; //TH1=0xFD;波特率9600
TL1=0xFD;
TR1 =1;
while(1)
{
if(k0==0&&y0==0){y0=1;SBUF=0xc0;led=0;}
if(k0==1){y0=0;}
if(k1==0&&y1==0){y1=1;SBUF=0xf9;led=0;}
if(k1==1){y1=0;}
if(k2==0&&y2==0){y2=1;SBUF=0xa4;led=0;}
if(k2==1){y2=0;}
if(k3==0&&y3==0){y3=1;SBUF=0xb0;led=0;}
if(k3==1){y3=0;}
if(k4==0&&y4==0){y4=1;SBUF=0x99;led=0;}
if(k4==1){y4=0;}
if(k5==0&&y5==0){y5=1;SBUF=0x92;led=0;}
if(k5==1){y5=0;}
if(k6==0&&y6==0){y6=1;SBUF=0x82;led=0;}
if(k6==1){y6=0;}
if(k7==0&&y7==0){y7=1;SBUF=0xf8;led=0;}
if(k7==1){y7=0;}
if(k8==0&&y8==0){y8=1;SBUF=0x80;led=0;}
if(k8==1){y8=0;}
if(k9==0&&y9==0){y9=1;SBUF=0x90;led=0;}
if(k9==1){y9=0;}
if(led==0)
{
while(!TI);
TI=0;
led=1;
}
}
}
#include<reg51.h>//接收
voidmain(void)
{
SCON=0x50; //REN=1允許串列接受狀態,串口工作模式1
TMOD|=0x20; //定時器工作方式2
PCON|=0x80; //數據位8、停止位1。效驗位無(12M)
TH1=0xFD; //TH1=0xFD;波特率9600
TL1=0xFD;
TR1 =1;
ES =1; //開串口中斷
EA =1; //開總中斷
P1=0xbf;
while(1)
{
}
}
voidchuankou(void)interrupt4
{
if(RI==1)
{
RI=0;
TI=0;
P1=SBUF; // 顯示0-9
}
}
⑺ 51單片機串列通信雙機通信模擬
從圖可知,兩個單片機各接一個八路撥碼開關,八個led。
可以這樣測試,上機讀取撥碼狀態,通過串口發送至下機,從而控制led。下機一樣。注意避免兩機通訊沖突。
只提供思路,具體程序自行解決。
⑻ 51單片機雙機通信最遠距離能有多遠
單片機雙機通信有很多模式,距離也是不一樣的。
UART-TTL1-2米,速率1M以內,有線連接,3條線(RXD-TXD、TXD-RXD、GND),串列全雙工。
SPI1米以內,速率10M以內,有線連接,5條線(含共地),主從模式雙工。
315M/2.4G無線模塊,速率100K以內,無線連接,可靠距離通常在50-100米,半雙工。
藉助於公共通信網路(GSM、CDMA、EVDO、電話線路),距離可以說是沒什麼限制了。
⑼ 51單片機雙機通信對晶振有要求嗎求高手解答~
對晶振沒有要求,但要求兩機的通訊設置完全一致,比如波特率,數據位,校驗位,停止位等。