atoi函数的实现及注意事项
在编写模拟实现atoi函数时,不应该只考虑到只有的数字字符串的简单情况,除此之外,还应该考虑到以下几种状况。
1. 指针为NULL
2. 空字符串
3. +,-号处理
4. 溢出处理
5. 遇到异常字符怎么处理
至于atoi函数的返回值,如果只是返回0或者1,没有状态标记,那么这个0或者1是正常状态的0或者1 ("0"),还是异常状态的0或者1("0abcd")。
一次应该加上一个全局变量控制当前转换后的数字是正常状态,还是异常状态。
对于保存最终的转换后的数字,我用的是long long 类型,原因是要用long long类型的数字与INT_MAX与INT_MIN比较,判断值是否溢出。
只有当前字符串转换到'\0'位置,则表示该数字是正常状态(其它情况在当前异常位置会结束字符串到数字的转换)。
#include<stdio.h>
#include<assert.h>
#include<ctype.h>
#include<limits.h>
//isdigit(),isspace()
int state = 1; //0表示正常,1表示异常
int My_atoi(const char *str){
assert(str);
int ret = 0;
int flag = 1;
// long long 是为了接受溢出int的数
long long num = 0;
// 空指针判断
if (NULL == str)
return ret;
//空字符串判断
if (*str == '\0')
return ret;
//跳过字符串起始的连续空格
while (isspace(*str))
{
str++;
}
// + - 号处理
if (*str == '-'){
flag = -1;
str++;
}
else if(*str=='+')
{
str++;
}
while (*str)
{
if (isdigit(*str)){
num = num * 10 + flag*(*str - '0');
// 溢出判断
if (num > INT_MAX){
ret = INT_MAX;
break;
}
if (num < INT_MIN){
ret = INT_MIN;
break;
}
}
else{
ret = num;
break;
}
str++;
}
//表示结果正常
if (*str == '\0'){
state = 0;
ret = num;
}
return ret;
}
int main(){
int ret = My_atoi("-12345678abc123");
if (state == 0){
printf("%d\n", ret);
}
else{
printf("异常数字:");
printf("%d\n", ret);
}
system("pause");
return 0;
}