什么是atoi函数
atoi函数是将字符串转化为数字字符。其形式如下:
int atoi (const char * str);
解析C-string的str,将其内容解释为整数,并返回int类型的值。该函数首先根据需要丢弃任意数量的空白字符,直到找到第一个非空白字符。然后,从这个字符开始,接受一个可选的初始加号或减号,后面跟着尽可能多的10进制数字,并将它们解释为数值。
这个字符串可以包含整数之后的其他字符,这些字符会被忽略,而且不会影响这个函数的行为。
如果str中的第一个非空白字符序列不是有效的整数,或者因为str为空或只包含空白字符而不存在此类序列,则不会执行转换并返回0。
一、核心思想
对于字符串转化为数字其实并不难,但是本题的核心在于考虑众多的异常情况,比如遇到如下情况该如何处理:
my_atoi(NULL)//异常
my_atoi("")//异常
my_atoi(" +123")//正常
my_atoi("-123")//正常
my_atoi("123abc")//异常
my_atoi("1111111111111111111111111")//异常
my_atoi("-1111111111111111111111111")//异常
二、代码的实现
# include <ctype.h>
# include<stdio.h>
enum Status //我们用枚举类型常量,来区分最后的数字是否是有效值
{
VALID,
INVALID
};
enum Status status = INVALID; //默认初始状态为非法
int my_atoi(const char* str)
{
//异常情况之空指针
if (str == NULL)
{
return 0;
}
//异常情况之空字符串
if (*str == '\0')
{
return 0;
}
//遇到空白字符跳过
if (isspace(*str))
{
str++;
}
//判断正负号,并把信息留存
int flag = 1;
if (*str == '+')
{
flag = 1;
str++;
}
else if (*str == '-')
{
flag = -1;
str++;
}
long long ret = 0; //防止字符串的数字过大,int类型存不下
while (isdigit(*str)) //-123
{
ret = ret * 10 + (*str - '0');
if (ret > _CRT_INT_MAX)
{
return 0;
}
str++;
}
ret *= flag;
if (*str == '\0')
{
status = VALID;
return (int)ret;
}
else
{
return 0;
}
}
int main()
{
int ret = my_atoi("12322");
if (status == VALID)
printf("合法的转换:%d\n", ret);
else
printf("非法的数据转换:%d\n", ret);
return 0;
}