STM32单片机中C语言的一些隐藏bug

必须类型一致的判断才能正常

c 复制代码
double a=-0.4;
if(a < -0.2){
	print("低电平");
}

这段代码可能未必如你所愿的运行. < 小于号的判断一定要类型一致, 尤其是牵扯到双精度类型的判断... 一定要保证符号 两边的数据类型一致才有可能得到你想要的结果. 代码里 -0.4 默认可能是float类型. 有的编译器默认是double类型. 一定要测试过才行.

不要使用 malloc函数获取内存

c 复制代码
float* aa= (float*)malloc(1000 * sizeof(float));
float* bb= (float*)malloc(1000 * sizeof(float));
float* cc= (float*)malloc(1000 * sizeof(float));

for (i = 0; i < signal->size; i++) 
{ 
    sindata[i] = sin(aa[i]);
    cosdata[i] = cos(aa[i]); 
    printf("%d  at Phase %f  sin is %f, cos is %f \r\n",i,referencePhase, referenceSin[i] , referenceCos[i] ); 
}

如果是这样的代码, 在PC上基本上是不会出什么问题, 如果是在STM32单片机上. 这么写估计会跑出来一大堆的问题.

为了这个问题我调试了大半天. 最终的原因在 动态分配内存 malloc() 函数上, 不一定能正确获得存储空间.

期初以为是float的精度不一致的问题, 逐行 printf 对比后才发现. 是malloc() 的问题.

改成

c 复制代码
float aa[1000]= {0};
float bb[1000]= {0};
float cc[1000]= {0};

for (i = 0; i < signal->size; i++) 
{ 
    sindata[i] = sin(aa[i]);
    cosdata[i] = cos(aa[i]); 
    printf("%d  at Phase %f  sin is %f, cos is %f \r\n",i,referencePhase, referenceSin[i] , referenceCos[i] ); 
}

把存储数据的变量改成全局静态的. 基本上不会出错.

不要在函数中初始化变量,尤其是大的数组变量.

c 复制代码
int main()
{  
    double signalData[2000];
    generateMultiSignal(signalData, 2000); 
    ...
}

这段代码中signalData 犯了2个错误,

1.在main函数中定义,

2.这里只是声明一个数组变量, 并非是初始化一个数组变量.

改成下面这么写就没问题了.

c 复制代码
double signalData[2000]={0};
int main()
{  
    generateMultiSignal(signalData, 2000); 
    ...
}

强制类型转换会丢失一个数值

c 复制代码
float anglea = 6.2900;
int indexb = (int)(anglea * 100);
printf("indexbbb: %d, angle: %f\n",  indexb, anglea);

理论上应该得到的是

indexbbb: 629, angle: 6.2900

但实际上得到的是

indexbbb: 628, angle: 6.2900

比实际值少了一个1?

c 复制代码
float anglea = 6.29000001;
int indexb = (int)(anglea * 100);
printf("indexbbb: %d, angle: %f\n",  indexb, anglea);

这样输出的值就是正常的. 具体原因不知.

开启DSP加速. 引用的lib库文件一定要正确.

引用 arm_cortexM4l_math.lib 时

c 复制代码
arm_sin_f32(123456)  

输出123456

正确的lib库应该是用 lf 的浮点库.

arm_cortexM4lf_math.lib

害我找了1天的bug啊...

另外如何开启DSP加速, 请参考下面的几篇文章

https://blog.csdn.net/WandZ123/article/details/125593908

https://zhuanlan.zhihu.com/p/462911261

https://blog.csdn.net/m0_74923693/article/details/136857288

printf 必须数据格式一致

c 复制代码
double age =18.0;
printf("age %f \r\n", age);

这会输出

age 0.00

正确代码如下

c 复制代码
double age =18.0;
printf("age %f \r\n", (float)age);
相关推荐
不穿格子衬衫4 小时前
常用排序算法(下)
c语言·开发语言·数据结构·算法·排序算法·八大排序
aqua35357423584 小时前
蓝桥杯-财务管理
java·c语言·数据结构·算法
CV金科4 小时前
蓝桥杯—STM32G431RBT6(IIC通信--EEPROM(AT24C02)存储器进行通信)
stm32·单片机·嵌入式硬件·算法·蓝桥杯
Word码5 小时前
数据结构:栈和队列
c语言·开发语言·数据结构·经验分享·笔记·算法
五花肉村长5 小时前
数据结构-队列
c语言·开发语言·数据结构·算法·visualstudio·编辑器
qinzechen5 小时前
分享几个做题网站------学习网------工具网;
java·c语言·c++·python·c#
嵌入式详谈6 小时前
基于STM32的智能风扇控制系统设计
stm32·单片机·嵌入式硬件
小小怪大梦想6 小时前
RTC实时时钟
stm32·单片机·嵌入式硬件
yttandb7 小时前
重生到现代之从零开始的C语言生活》—— 内存的存储
c语言·开发语言·生活
结衣结衣.7 小时前
python中的函数介绍
java·c语言·开发语言·前端·笔记·python·学习