while(RI); //接收数据,若字符未接受完,一直等待
{
RI=0;
temp[num]=SBUF;
num++;
endmark=1;
/***************************************************************************************************************
假如你波特率为9600,那么接收一个位时间大概为100us,假如你的单片机执行一条语句1us,
那么你用查询的方式有可能会是你只接收到第一个字节后,就会推出这个while循环.
***************************************************************************************************************/
}
建议你用串口中断的方式来接收多个字节的数据,下面是我之前写过的程序
/******************************************************************************************
串口中断函数
ReData[]: 里是一个字节类型的数组,这里一次只接收4个字节数据.
********************************************************************************************/
void Usart_isr() interrupt 4 using 2
{
if(RI)
{
ReData[ReceiveCount++] = SBUF;
if(ReceiveCount > 3)
{
ReceiveCount = 0;
}
RI = 0;
}
}
1、在temp[num]=SBUF增加一个点灯的代码 ,这样可以判定是串口是否收到数据;
2、串口中断里面要作数组越界判断,具体是在num++;之后判定 这个num是否已经超过了你定义的temp[]这个数组的界限;
3、由于在板子上电时,串口上可能有浪涌数据(这个数据是一个随机的值),所以可能导致你串口收到的数据里面0x31数据并不是在temp[1]中,最好让串口收到数据后立即也将数据发回到电脑
4、检查你串口初始化时波特率是否设置正确,串口收发端的波特率是否是匹配的。
1.你先显示num这个变量试试,看你是否接收到了数据。
2. 把显示数值换成一个常数,试试你的显示是否正常
1)num没有赋初值,是在循环外赋值了吧;
2)RI 放在循环里,会不断被清零,那么其在哪里,什么条件下,值被改变;
3)if (temp[1]==0x31) 语句中,如果接收的数据没有符合条件的,自然的,就不会执行其下面的输出语句了;
程序发完吧,看上去是RI那里有问题。