系列文章目录
前言
提示:
- 这篇文章记录一个问题,如果有解决的希望能够评论区给出宝贵的建议。
- 在使用ESP32系列的串口接收电脑数据,并使用sprintf将其解析为float类型的浮点数据的时候,应该是数据溢出导致的芯片重置
提示:
一、问题代码
- 如下类似的过程就会直接触发芯片复位
- 使用xTaskCreate(rx_task, “uart_task”, 2048, NULL, 10, NULL);创建一个接收进程后,在进程中写入如下代码。
char data[512]={0};
float P=0.0f;
const int rxByte=uart_read_bytes(UART_NUM_1,data,RX_BUF_SIZE,100/10);
sprintf(data,"%f",P);
- 关键代码就是上面这些,和一般的处理没什么太大区别,但是在接收上位机传来的数据的时候,就是会解析并向上位机返回解析后的信息后直接复位芯片,而解析的数据本身没有问题。
- 而最主要的是什么呢,这个解析的数据在0.1111或者1.121324等等这些小数点后面是0以外的数字的情况下,是能够正常解析数据的,并且不复位芯片
- 但是只要是0.01111或者0.034214这些小数点后首位是0的数据,就会造成芯片复位。而1.0111或者2.0141234这些数据都没问题。
- 比较魔幻。
二、解决办法
- 解决方法还是比较随意,但是我没有找到根本原因,理论上不可能是我上下文代码问题,因为主要代码就是如上那些。
- 使用strtof进行数据解析就行,这个是c中专门用于字符串转浮点数类型的函数,使用方法如下
data[512]={0};
// 定义一个字符指针p,用于解析接收到的数据
char *p;
angle = strtof(data, &p);
Ps = strtof(p + 1, &p);
- 用于基本的浮点数处理还是没有问题的,但是不适合复杂的字符串处理
总结
提示::
至于出问题的原因,还没找到,所以如果有人遇到过类似的情况还请告知。