上一篇说到串口协议的封包与拆包,主要要是应用于单片机与单片机通讯,或者与上位机程序通讯,这里我是与上位机程序通讯。
思路:
因为此功能是用c语言写的,所有在单片机上可以使用,在pc机上也是可以使用的。
这是单片机主函数代码:
int main(void)
{
delay_init(); //延时函数初始化
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);// 设置中断优先级分组2
uart_init(115200); //串口初始化为9600
LED_Init(); //初始化与LED连接的硬件接口
wifi_buff_init();
printf("ok ing...\r\n");
while(1)
{
analyze_queue(); //处理数据
set_tx_data("hello",5); //发送hello过去,这里面是对此数据封过包的
delay_ms(100);
}
}
这里是上位机程序代码逻辑,代码涉及过多,都是以前写过的类,这里就不重复贴了。
首先调用初始化函数wifi_buff_init();
用一个线程去读取串口数据,调用add_message_queue(ch);函数把数据加入队列。
//接收数据
DWORD WINAPI Thread_fun1(LPVOID pM)
{
char ch;
while(1)
{
COM.Read_Byte(ch); //从串口读取数据,此功能是以前封装的
TRAN.add_message_queue(ch); //把数据加入到队列,只是把wifi_data_tran.c文件改成wifi_data_tran.cpp
}
}
另一个线程负责解析数据,调用analyze_queue();解析数据
//处理数据
DWORD WINAPI Thread_fun2(LPVOID pM)
{
while(1)
{
TRAN.analyze_queue();
}
}
因为时间问题,上位机就没有做成MFC了,这里用控制台代替
看看数据解析效果
recv:0:48 45 53 5a 4a 7 0 0 5 0 0 0 68 65 6c 6c 6f
这一段数据就是解析出来的包,包有任何错误不都会解析出来的,从程序打印来看,验证了4个包头,长度,数据长度,校验。