函数原型:
char* itoa(int value, char* buf, int radix);
value:要转换的参数
buf:转换后存储的空间
radix:按radix进制转换
在使用的时候发现了一个问题,以前没关注过,如下:
char temp;
int a = 1;
itoa(a, &temp, 10); //将a==1按10进制转换后存入temp
结果报错信息:Run-Time Check Failure #2 - Stack around the variable 'temp' was corrupted.
运行时栈错误,后来经过查找发现是itoa转换后要在buf最后添加NULL结束符,而temp只是一个字符,这就导致NULL添加不成功!
正确的做法是:
char temp[2];
int a = 1;
itoa(a, temp, 10);
这样就对了,但是当把a改为两位数后有可能会有错误,因为转换后的每个数字都要占一个char的位置,也就是说如果a==1234,那么temp大小必须至少是5个,即四个数字加一个NULL结束符。
如果a为负数呢,假设a == -1067,那么temp大小应该为多少呢? 实际上temp大小应该再加1,因为
temp[0]存储的是符号('-'),如下图所示:
那么如果是正数有没有符号位呢? 单步发现只有负数前面才有符号位,所以结论如下:
如果val为正数,则buf大小应该为val位数加1,末位为NULL位;
如果val为负数,则buf大小应该为val位数加2,buf[0]为负号,末位为NULL位。
切记!
PS:VS2010下使用itoa显示该warning C4996: 'itoa': The POSIX name for this item is deprecated. Instead, use the ISO C++ conformant name: _itoa. See online help for details.
即该函数itoa过时了,应该使用ISO C++ conformant函数名 _itoa, 在使用_itoa时有提示可能不安全,让使用_itoa_s。