字符串转换为整数

一道看似很简单的题,其实需要考虑很多情况。
1)需检测输入字符串的有效性
2)需跳过字符串前面的空格字符
3)需检测数字的正负性
4)需判断数字是否溢出

代码如下:
int My_atoi(char *str)
{
assert(str != NULL);
int overFlag = 0;

if (str == "")
{
    return 0;
}
char *inputStr = str;
while (isspace((int)*inputStr))
{
    inputStr++;
}                                              //跳过前面的空格换行等空格字符
int num = 0;
char sign = 0;
if (*inputStr == '\0')
{
    return 0;
}
else
{
    if (*inputStr == '-' || *inputStr == '+')
    {
        sign = *inputStr++;            //得到符号位
    }
    while (isdigit((int)*inputStr))
    {
        num = num * 10 + *inputStr - '0';
        if (num < 0)
        {
            overFlag = 1;
            break;
        }                                      //判断是否溢出
        inputStr++;
    }
}
if (sign == '-')
{
    if (overFlag)
    {
        return INT_MIN;
    }
    return -num;
}
else
{
    if (overFlag)
    {
        return INT_MAX;
    }
    return num;
}                               //判断符号位以及是否溢出整数范围

}

猜你喜欢

转载自blog.csdn.net/rlyhaha/article/details/79858908