最近在做项目中发现一个Bug,直接把进程搞死,查了一下,居然是一个最不起眼的地方导致的,在此记录一下。
先看下面代码
#include <iostream> #include <stdio.h> using namespace std; int main() { char aa[1024] = {0}; float f = 50.123456; // 本意是想把一个浮点数输出到字符串中,小数位为两位,漏了 sprintf(aa, "%0.*f", f); printf("%f ", f); cout<<aa<<endl; sprintf(aa, "%0.*f", 2, f); cout<<aa<<endl; cout << "Hello world!" << endl; return 0; }
运行结果如下
代码中,sprintf(aa, "%0.*f", f);是想把一个浮点数输出到字符串中,且想控制小数点后的位数,但是在后面没有传参数指定小数点位数,导致sprintf打印了一长串数据到变量aa中。当aa的空间不足时,就会使得数组越界,导致程序崩溃。在项目中进程被搞死的原因就在于此。至于sprintf函数内部是怎么打印出这么长一串数据的,等看了源码后再分析。