• 【atoi函数详解】


    一. 什么是atoi函数

    atoi函数是将常量字符串转化为整数

    int atoi(const char str);*

    注意:该函数的返回值为int,所以不能超过int范围,如果数字很大超过就会截断,返回截断后的值即int的最大左右范围值。
    举个例子:

    #include 
    #include 
    int main()
    {
    	int ret1 = atoi("-123");
    	int ret2 = atoi("11111111111111111111111");
    	printf("%d\n", ret1);
    	printf("%d\n", ret2);
    	printf("%d\n", INT_MAX);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    结果表明超过int范围的值结果会截断,截断后值和int最大值一样。
    在这里插入图片描述

    二. 模拟实现函数atoi

    上面不理解,没事,看例子——》
    例子一:传一个空字符串
    例子二:情况二、传一个空指针
    例子三:传一个空格加整数的字符串
    例子四:传一个整数加字母的字符串
    例子五:传一个字母加整数字符串
    例子6:传一个负整数

    #include
    #include
    #include
    #include
    
    int main()
    {
    	printf("%d\n", atoi(""));
    	printf("%d\n", atoi("    123"));
    	printf("%d\n", atoi("123sgsdg"));
    	printf("%d\n", atoi("adgd123"));
    	printf("%d\n", atoi("-123"));
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这里插入图片描述
    例子一和四都是非法转换,所以模拟实现要先处理这两种情况:

    #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;
    	}
    	//空白字符
    	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);
    	else
    		printf("非法转换:%d\n", ret);
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65

    三. 总结atoi

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

    小弟制作不易,劳烦各位兄弟点点小小的关注,谢谢了

  • 相关阅读:
    传统运维与云运维到底有什么不同呢?
    springAOP落地实现
    构建api gateway之 openresty 中如何使用 wasm
    性能调优——小小的log大大的坑
    SpringCloud 微服务全栈体系(十三)
    智能优化与机器学习结合算法实现数据预测matlab代码清单
    MEA优化BP神经网络的压力脉动预测方法
    第五章:Python中的集合(上)
    数字化建设方案
    二叉排序树的查找、插入、创建和删除
  • 原文地址:https://blog.csdn.net/2301_76560014/article/details/133817929