标签:c语言 函数 字符串
我们知道C语言有一个库函数atoi (表示 alphanumeric to integer)是把字符串转换成整型数的一个函数。那么如何实现这个函数呢?
很多同学很快会写出下列代码:
int StrtoInt(char str[])
{
assert(str);
int num=0;
while(*str)
{
num=num*10+*str-‘0‘;
++str;
}
return num;
}这个代码有没有什么漏洞呢?虽然用了assert来检查了空指针,但是,试想一下,如果我们传进去的字符串是一个有符号的数呢?正整数的加号可以省略,但是负数呢?是不是还应该再修改一下。此外,我们传进去的字符串是不能修改的吧。该用const修饰吧。考虑正负数的问题,我们将程序中加入一个flag标志位用来记录正负数。改进程序如下:
int StrtoInt( const char str[])
{
assert(str);
int num=0;
int flag=1;
if(*str==‘+‘)
{
str++;
}
else if(*str==‘-‘)
{
flag=-1;
str++;
}
while(*str)
{
num=num*10+*str-‘0‘;
str++;
}
return flag*num;
}接下来,我们是不是要考虑在开始的时候检查一下非法输入呢?检查非法输入外,是不是还要考虑一下溢出问题呢?这些都是一名优秀的编程人员考虑范围。下面让我们来参考一下《剑指offer》这本书中对这个问题的解答吧!
参考代码如下:
long long StrToIntCore(const char* str, bool minus);
enum Status {kValid = 0, kInvalid};
int g_nStatus = kValid;
int StrToInt(const char* str)
{
g_nStatus = kInvalid;
long long num = 0;
if(str != NULL && *str != ‘\0‘)
{
bool minus = false;
if(*str == ‘+‘)
str ++;
else if(*str == ‘-‘)
{
str ++;
minus = true;
}
if(*str != ‘\0‘)
{
num = StrToIntCore(str, minus);
}
}
return (int)num;
}
long long StrToIntCore(const char* digit, bool minus)
{
long long num = 0;
while(*digit != ‘\0‘)
{
if(*digit >= ‘0‘ && *digit <= ‘9‘)
{
int flag = minus ? -1 : 1;
num = num * 10 + flag * (*digit - ‘0‘);
if((!minus && num > 0x7FFFFFFF)
|| (minus && num < (signed int)0x80000000))
{
num = 0;
break;
}
digit++;
}
else
{
num = 0;
break;
}
}
if(*digit == ‘\0‘)
{
g_nStatus = kValid;
}
return num;
}一个简单的问题在经过仔细考虑之后可以写出如此长的代码,这个例子对我们还是一个警示,对可能出现的情况都要考虑到,减少BUG。希望带给初学者一些帮助。
本文出自 “柠公子” 博客,转载请与作者联系!
标签:c语言 函数 字符串
原文地址:http://luminous.blog.51cto.com/10797288/1738434