【C语言】- 模拟实现atoi函数

atoi()函数的功能:将字符串转换成整型数;atoi()会扫描参数字符串,跳过前面的空格字符,直到遇上数字或正负号才开始做转换,而再遇到非数字或字符串时('\0')才结束转化,并将结果返回(返回转换后的整型数)。

我们在传参的时候需要解决以下问题:

空指针
空字符串
非数字字符
前面有空白字符
前面有+-
溢出

#include <stdio.h>
#include <assert.h>
#include <ctype.h>
#include <limits.h>

enum Status
{
	VALID,//合法
	INVALID//非法
}status = INVALID;

int my_atoi(char* str)
{
	//空指针 
	assert(str);

	//空字符串
	if (*str == '\0')
	{
		return 0;
	}
	//空白字符
	while (isspace(*str))//查看是否为空白字符
	{
		str++;
	}
	//正负号
	int flag = 1;//正号
	if (*str == '+')
	{
		flag = 1;
	}
	else if (*str == '-')
	{
		flag = -1;
		str++;
	}

	long long n = 0;
	while (*str!='\0')
	{
		if(isdigit(*str))//查看是否为数字字符
		{
			n = n * 10 + flag * (*str - '0');
			if (n > INT_MAX || n < INT_MIN)
			{
				if (flag == 1)
				{
					return INT_MAX;
				}
				else if (flag == -1)
				{
					return INT_MIN;
				}
				break;
			}
		}
		else
		{
			break;
		}
		str++;
	}

	if (*str == '\0')
	{
		status = VALID;
	}
	 return (int)n;
}

int main()
{
	char arr[] = "111111111111111111111111";
	int ret = my_atoi(arr);
	if (status == VALID)
	{
		printf("正常转换:%d\n", ret);
	}
	else
	{
		printf("非法转换:%d\n", ret);
	}
	
	return 0;
}

这里溢出的时候,正的返回INT_MAX和负的返回INT_MIN 

猜你喜欢

转载自blog.csdn.net/qq_54880517/article/details/124080211