完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我自己借鉴别人程序写了一个接收短信程序,可是一直读不出短信,不知道问题出在哪,我弄了几个LED指示灯发现程序卡在while(1)后判断是否有+CMti那了,一直判断不出来。还有我程序里明明写了删除所有短信,可是我用串口调试助手调试时发现短信并没有被删除,求大神帮帮忙。 #include #include #include #define uchar unsigned char #define uint unsigned int ***it LED0=P1^0; ***it LED1=P1^1; ***it LED2=P1^2; ***it LED3=P1^3; //***it LED4=P1^4; //以下用于保存单片机收到模块发来的AT指令,通过这些指令单片机可以判断模块的状态 uchar GsmRcv[100] = {0}; uchar GsmRcvAt[100] = {0}; uchar GsmRcvCnt = 0; uchar GsmAtFlag = 0; //注意,无论接收到信号还是发送完信号,都会进中断服务程序的 /*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/ void SerialInti()//初始化程序(必须使用,否则无法收发) { TMOD=0x20;//定时器1操作模式2:8位自动重载定时器 TH1=0xfd;//装入初值,波特率9600 TL1=0xfd; TR1=1;//打开定时器 SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制) SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据 SM2=0; REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许) EA=1;//开总中断 ES=1;//开串行口中断 } /*串行通讯中断,收发完成将进入该中断*/ void Serial_interrupt() interrupt 4 { uchar i = 0; if(RI == 1) //收到信息 { RI=0;//接收中断信号清零,表示将继续接收 GsmRcv[GsmRcvCnt] = SBUF; // Uart1Send(tmp); GsmRcvCnt++; //收到了完整的AT指令,完整的AT指令是以0x0a 0x0d结尾的。故作此判断,在接收的过程中是否收到0x0a 0x0d if(GsmRcv[GsmRcvCnt-2] == 0x0d && GsmRcv[GsmRcvCnt-1] == 0x0a && GsmRcvCnt >= 2) { //一旦收到0x0a 0x0d,就将数据保存起来。用户主函数的判断。 for(i=0; i GsmRcvAt = GsmRcv; GsmRcv = 0; // LED0=0; } GsmRcvCnt = 0; GsmAtFlag = 1;//收到了完整的at指令,通过这个标志位置1,这样主函数就知道去判断了。 LED2=0; } else if(GsmRcvCnt >= 100)//因为内存有限,收到了100个字符还是没有看到0x0a 0x0d的话,就重新开始接收吧。 { GsmRcvCnt = 0; // LED1=0; } } } void Uart1Send(uchar c) { SBUF=c; while(!TI);//等待发送完成信号(TI=1)出现 TI=0; } //串行口连续发送char型数组,遇到终止号/0将停止 void Uart1Sends(uchar *str) { while(*str!=' |