目录
一、atoi函数的介绍
二、atoi函数的使用
三、atoi函数的模拟实现
一、atoi函数的介绍
一个专门将字符串转换为整数的库函数,具体用法如下:
字符串str,将其内容转化为整数,该整数作为int值返回。
二、atoi函数的使用
atoi函数的使用是非常简单的,如下:
int main()
{int ret = atoi(" -123");printf("%d\n", ret);return 0;
}
运行如下:
三、atoi函数的模拟实现
重要板块:模拟实现需要我们将所有可能出现的情况列举出来,才能够完美的模拟实现出atoi库函数,情况如下:
字符串 | 合法性 |
“” | 非法 |
“NULL” | 非法 |
“ 123” | 合法 |
“123abc” | 非法 |
“-123” | 合法 |
“11111111111111111” | 非法 |
1、字符串可以在构成整数的字符之后包含其他字符,这些字符将被忽略,并且对该函数的行为没有影响。
例如:123abc转换成123,字符被忽略,这种情况属于异常情况。
2、该函数可以跳过多余的空白字符,直到找到第一个非空白字符。然后,从这个字符开始,取一个可选的初始加号或减号,后面跟着尽可能多的数字,并将它们转化为整数值。
例如:-123转换成-123。这种情况属于合法情况。
3、如果字符串的第一个非空白字符序列不是有效的整数,或者是字符串为空或只包含空白字符,则不执行转换。这种情况属于非法转换。
4、最后一种的转化情况之所以是非法转换,是因为整数值的大小是有限制的,太大的话,会出现越界,所以返回值有可能为随机值。
模拟实现atoi库函数的代码如下:
#include <limits.h>
#include <ctype.h>
//设置两种状态,分别代表字符转换的合法性
enum Status
{VALID,//合法INVALID//异常
};
enum Status status = INVALID;
int my_atoi(const char* str)
{if (str == NULL){return 0;}if (*str == '\0'){return 0;}//处理空白字符while (isspace(*str))//如果前面有空格,跳过空格往后寻找符号或数字{str++;}int flag = 0;if (*str == '+'){flag = 1;str++;}else if (*str == '-'){flag = -1;str++;}//处理数字字符//-123long long ret = 0;while (isdigit(*str)){ret = ret * 10 + flag*(*str - '0');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;
}
本文要是有不足的地方,欢迎大家在下面评论,我会在第一时间更正。