這是大神的原代碼
#include <reg52.h>
#include <stdio.h> //printf頭文件
#define uc unsigned char
#define uint unsigned int
uc flag,i,flag_t,s[50]="",j=0,flag_n=0;
uc code table[]="I get ";
void init()
{
TMOD=0x20; //定時器工作方式,選擇了定時器1,工作方式2 八位初值自動重裝的8位定時器。
TH1=0xfd; //定時器1初值 ,設置波特率為9600 晶振11.0529MHZ?
TL1=0xfd;
TR1=1; //開啟定時器1
SM0=0;
SM1=1; //10位異步接收,(8位數據)波特率可變
REN=1; //允許串行口接收位
EA=1; //允許中斷(總閘)
ES=1; //允許串口中斷
}
void main()
{
init();
while(1)
{
if(flag==1)
{ if(flag_n!=0) //使第二個及以后I get xx 換行,不與You transfer在一行
{TI=1;
printf("\n");
while(!TI);
TI=0;
}
for(i=0;i<6;i++)
{
SBUF=table[i];//串口緩沖器
while(!TI);
TI=0;
}
for(i=0;s[i]!='#'&&i<50;i++)
{
SBUF=s[i];
while(!TI);
TI=0;
}
flag=0;
}
if(flag_t==1) //發送完畢之后,在電腦端輸出。
{
TI=1; //printf之前必須將T1置為1才行。
printf ("\nYou transfer %s",s);
while(!TI);
TI=0;
flag_t=0;
}
}
}
void ser() interrupt 4
{
if(RI) //接收數據,手動將RI清0串行口的接收中斷標志
{
RI=0;
if(flag==0&&j!=0)//1.循環賦值為'\0'(字符串結尾標志符),j=0,為了第二次傳遞字符串是又是從頭輸出
{ //2.flag為0和j不為0時,保證是第二次及以后,傳輸字符串(控制輸出格式)
flag_n++;
for(j=0;s[j]!='#'&&j<50;j++)
s[j]='\0';
j=0;
}
s[j]=SBUF;
flag=1;
if(s[j]=='#'||j==49) //以'#'作為傳送字符串的結尾符,我定義的字符數組最長為50所以49也應該結束。
flag_t=1;
else
j++;
}c
if(TI) //發送數據
{
}
} |