关于itoa函数使用到时候犯的错误

来源:互联网 发布:北京80越野车数据 编辑:程序博客网 时间:2024/06/07 14:36

http://hi.baidu.com/cuihao0532/item/31ae5d62e9a3381d6895e6b6

函数原型:

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。


0 0
原创粉丝点击