目录

  • 一、什么是atoi函数
  • 二、模拟atoi

一、什么是atoi函数

atoi函数是将字符串转换成整数。

int atoi (const char * str);

该函数的返回值为int类型的整数,转换后的值不可超出int可表示的范围。

注意:

1、该函数首先会丢弃尽可能多的空白字符,直到找到第一个非空白字符,然后,从这个字符开始,取一个可选的初识加号或者减号,后跟尽可能多的十进制数字,并将他们返回一个int类型的数值。
2、若该字符串是在整数的字符后包含其他字符,则这些字符将会被忽略,返回其他字符之前的整数,并且不会对该函数造成任何影响。
3、若该字符串中第一个非空字符序列表示有效的整数,或是一个空指针,或只包含空白字符,则不执行任何转换,并且返回零。

举个例子:

#include #include int main(){int ret = atoi("-123");printf("%d\n", ret);}

二、模拟atoi

在模拟atoi函数之前,我们应该考虑以下几种情况
情况一、传一个空字符串

my_atoi(“”);

情况二、传一个空指针

my_atoi(“NULL”);

情况三、传一个非常大的数字

my_atoi(“111111111111111111111111111111111”);

情况四、传一个非常大的负数

my_atoi(“-111111111111111111111111111111111”);

情况五、传一个整数加字母的字符串

my_atoi(“123asd”);

情况六、传一个空格加整数的字符串

my_atoi(“      123”);

情况七、传一个负数的字符串

my_atoi(“-123”);

以上几种情况那些是非法的,那些又是合法的呢?
下面我们来用代码实现:

#include #include #include enum Status{VALID,INVALID};enum Status status = INVALID;int my_atoi(const char* str){if (str == NULL){return 0;}if (*str == '\0'){return 0;}//k=空白字符while (isspace(*str)){str++;}int flag = 1;if (*str == '+'){flag = 1;str++;}else if (*str == '-'){flag = -1;str++;}//处理数字字符long long ret = 0;while (isdigit(*str)){ret = ret * 10 + (*str - '0') * flag;if (ret<INT_MIN || ret>INT_MAX){return 0;}str++;}if (*str == '\0'){status = VALID;return (int)ret;}else{return (int)ret;}}int main(){int ret = my_atoi("-123");if (status == VALID)printf("合法转换:%d\n", ret);elseprintf("非法转换:%d\n", ret);return 0;}

经过测试:
(1)、情况一、二、三、四、五是非法的
情况一、二、三、四结果如下:

情况五的结果如下:

(2)、情况六、七是合法的
情况六的结果如下:

情况七的结果如下: