atoi函数的详细实现(考虑溢出)

  atoi()函数的功能:将字符串转换成整型数。atoi()会扫描参数str字符串,跳过前面的空白字符,直到遇上数字或正负号才开始做转换,而再遇到非数字或字符串时('\0')才结束转化,并将结果返回(返回转换后的整型数)。

写atoi函数的时候需要注意一下几点

1. 忽略字符串前的空白字符
2. 字符串所表示数值的正负号

3. 结束条件,遇到非数字或者字符'\0'结束

4. 考虑溢出,分别与int值所能表示的最大(0x7fffffff)和最小值(0x8000000)进行比较
5. 考虑异常输入情况下

atoi()函数实现的代码:strToInt()

strToInt.h文件

#ifndef STRTOINT_H
#define STRTOINT_H
#include <iostream>
#define INT_MAX ((int)0x7fffffff)
#define INT_MIN ((int)0x80000000)
int strToInt(const char* str){
	long long result=0; //8个字节长度
	int flag=1;//默认正数
	//判断指针是否为空
	if (str==NULL)
		return 0;	
	//跳过前面的空白字符
	while(isspace(*str)){
		++str;
	}
	/*
	*判断正负号
	*/
	if(*str=='-'){
		flag=-1;
		str++;
	}else if(*str=='+')
		str++;
	//把数字字符逐个转换成整数,并校验溢出,溢出返回0
	while(*str<='9' && *str>='0'){
		result=result*10+*str-'0';
		if(flag==1){ //校验是否正溢出
			if(result>INT_MAX)
				return 0;
		}else{ //校验负溢出
			if(-result<INT_MIN)
				return 0;
		}
		str++;
	}
	return (int)flag*result;
}
#endif

main.cpp文件
#include "strToInt.h"
#include <iostream>
#include <stdlib.h>
using namespace std;
int main(){
	const char * str1="-00067";
	cout<<strToInt(str1)<<endl;
	const char *str2="\r\t\n-671231"; //前导空白字符
	cout<<strToInt(str2)<<endl;
	const char *str3="  -671 231"; //非法空格字符
	cout<<strToInt(str3)<<endl;
	const char *str4="+671231";
	cout<<strToInt(str4)<<endl;
	const char *str5="671 ";
	cout<<strToInt(str5)<<endl;
	const char *str6="67123222433434 "; //正溢出
	cout<<strToInt(str6)<<endl;
	const char *str7="-67123222433434 ";//负溢出
	cout<<strToInt(str7)<<endl;
	return 0;
}


运行结果


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
下面是一个较为详细的版本的atoi函数源码示例: ```c #include <stdio.h> #include <stdlib.h> #include <ctype.h> int atoi(const char *str) { int num = 0; int sign = 1; int i = 0; // 处理空白字符 while (isspace(str[i])) i++; // 处理正负号 if (str[i] == '-' || str[i] == '+') { sign = (str[i] == '-') ? -1 : 1; i++; } // 转换数字 while (isdigit(str[i])) { if (num > INT_MAX / 10 || (num == INT_MAX / 10 && (str[i] - '0') > INT_MAX % 10)) { // 处理溢出情况 if (sign == 1) return INT_MAX; else return INT_MIN; } num = num * 10 + (str[i] - '0'); i++; } return num * sign; } int main() { char str[] = "12345"; // 要转换的字符串 int num = atoi(str); // 使用自定义的atoi函数将字符串转换为整数 printf("转换后的整数为: %d\n", num); return 0; } ``` 这个版本的atoi函数与之前的简化版相比,增加了以下功能: - 使用`isspace`函数处理空白字符,而不仅仅是处理空格和制表符。 - 增加了溢出检查,以避免将超出整数范围的字符串转换为整数。如果溢出,则根据符号位返回INT_MAX或INT_MIN。 在上述示例中,我们首先包含了`stdlib.h`、`stdio.h`和`ctype.h`头文件。然后,我们定义了一个自定义的atoi函数,它接受一个指向const char类型的字符串,并返回相应的整数。 最后,我们在main函数中使用自定义的atoi函数将字符串转换为整数,并打印出转换后的结果。 请注意,这只是一个较为详细的版本的atoi函数示例。实际的atoi函数可能会更复杂,考虑更多的边界条件和错误处理情况。此外,该实现还未考虑负号后面跟随非数字字符的情况,如果你需要更严格的实现,请根据具体需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值