详解atoi函数

目录


一、什么是atoi函数

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

int atoi (const char * str);

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

注意:

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

举个例子:

#include <stdio.h>
#include <stdlib.h>
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 <stdio.h>
    #include <ctype.h>
    #include <limits.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 = 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)、情况六、七是合法的
      情况六的结果如下:
      在这里插入图片描述
      情况七的结果如下:
      在这里插入图片描述

      • 0
        点赞
      • 1
        收藏
        觉得还不错? 一键收藏
      • 0
        评论
      评论
      添加红包

      请填写红包祝福语或标题

      红包个数最小为10个

      红包金额最低5元

      当前余额3.43前往充值 >
      需支付:10.00
      成就一亿技术人!
      领取后你会自动成为博主和红包主的粉丝 规则
      hope_wisdom
      发出的红包
      实付
      使用余额支付
      点击重新获取
      扫码支付
      钱包余额 0

      抵扣说明:

      1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
      2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

      余额充值