起因
在用一个别人的程序时,出现了设备死机的现象。但是同样的程序别人使用没有问题。经过排查发现生成的bin文件大小和别人的不一样。开始以为是keil和keil编译器的版本不同的问题,但是换成相同的版本还是不行,最后发现是keil配置的优化等级不一样
这个东西会影响生成的bin文件大小和调试,开始我的选成了【default】,选成0就正常的。虽然不太理解为什么优化会影响功能但是确实是这个设置的原因。
各个等级的作用
优化等级0
Minimum optimization. Turns off most optimizations.It gives the best possible debug view and the lowest level of optimization.
近乎不优化,用于调试代码。出现代码行不能设置断点可如此设置试试。
特点:最少的优化,可以最大程度上配合产生代码调试信息,可以在任何代码行打断点,特别是死代码处。
优化等级1
Restrictedoptimization. Removes unused inline functions and unused static functions.Turns off optimizations that seriously degrade the debug view. Ifused with --debug, this option gives a satisfactorydebug view with good code density.
部分优化。移除未调用的内联函数和静态函数,关闭debug窗口优化,此状态也能用于调试
特点:有限的优化,去除无用的inline和无用的static函数、死代码消除等,在影响到调试信息的地方均不进行优化。在适当的代码体积和充分的调试之间平衡,代码编写阶段最常用的优化等级。
优化等级2
Highoptimization. If used with --debug, the debug viewmight be less satisfactory because the mapping of object code tosource code is not always clear.This is the default optimization level.
默认优化等级。如果处于debug状态,部分代码行将不能被调试,具体做了什么优化好像没说
特点:高度优化,调试信息不友好,有可能会修改代码和函数调用执行流程,自动对函数进行内联等。
优化等级3
Maximumoptimization. -O3 performs the same optimizationsas -O2 however the balance between space and timeoptimizations in the generated code is more heavily weighted towardsspace or time compared with -O2.
等级3和等级2除了执行相同的优化,还有在空间和时间之间的平衡优化在生成的代码中比等级2更重的空间或时间。
特点:最大程度优化,产生极少量的调试信息。会进行更多代码优化,例如循环展开,更激进的函数内联等。