atoi函数的实现及注意事项

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
#include
#include
#include
//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;
}


你可能感兴趣的:(atoi函数的实现及注意事项)