atoi函数详解

atoi函数使用方法

在c++官网中是这样介绍atoi函数的
在这里插入图片描述
通俗的讲就是把字符串中的字符数字转换为整形数字,遇到空格就跳过,如果在字符串开始遇到不是有效的整数比如说abc就直接返回0,如果遇到像这种情况123abc345这个就只返回123,这个函数包含在stdlib.h头文件里我们来试一下

# define _CRT_SECURE_NO_WARNINGS
# include<stdio.h>
# include<stdlib.h>int main()
{char arr[] = { "   123abc345" };char arr1[] = { "  abcd123" };char arr2[] = { "  -123sdf" };char arr3[] = { "  @aq1234" };int ret = atoi(arr);int ret2 = atoi(arr1);int ret3 = atoi(arr2);int ret4 = atoi(arr3);printf("%d\n%d\n%d\n%d\n", ret,ret2,ret3,ret4);return 0;
}

在这里插入图片描述

模拟实现atoi

在模拟实现之前我们要考虑清楚有几种情况,第一种就是传的字符串是空指针,第二种是开头有空格需要跳过,第三种就是开头是除开0到9的字符,第四种就是开头是数字字符是正数还是负数,还有就是合法转换和非法转换。下面是代码

# define _CRT_SECURE_NO_WARNINGS
# include<stdio.h>
# include<ctype.h>
# include<stdlib.h>
# include<assert.h>
enum State
{VAILD,//不非法的 INVAILD//非法的
} state = INVAILD;int my_atoi(const char* str)
{assert(str != NULL);if (*str == '\0'){return 0;}while (isspace(*str)){str++;}int flag = 1;if(*str == '-'){flag = -1;str++;}if (*str == '+'){flag = 1;str++;}long long ret = 0;while (*str != '\0'){if (isdigit(*str)){ret = ret * 10 + (*str - '0')*flag;if (ret > INT_MAX){return INT_MAX;}if (ret < INT_MIN){return INT_MIN;}}else{return (int)ret;}str++;}if (*str == '\0'){state = VAILD;}return (int)ret;
}
int main()
{char str[] = { "  -123abc34" };int ret = my_atoi(str);if (state == VAILD){printf("合法转化:%d\n", ret);}else{printf("不合法转化:%d\n", ret);}return 0;
}

分布讲解

nt my_atoi(const char* str)
{assert(str != NULL);if (*str == '\0'){return 0;}while (isspace(*str)){str++;}int flag = 1;if(*str == '-'){flag = -1;str++;}if (*str == '+'){flag = 1;str++;}

这一段代码就是解决如果 字符串中的第一个非空格字符序列不是有效的整数,或者由于空或仅包含空格字符而不存在此类序列,则不执行转换并返回零。还有遇到空格字符跳过的情况,这样用了一个函数isspace这个函数就是用来判断是不是空格字符,并且断言了一下传过来的字符串是不是空指针,
如果都不是就进入下面的if语句这里主要就是判断是正数还是负数,其实正数是不需要判断前面是不是有加号的,这样做就主要是为了防止有这样的字符串传过来像+123这种情况,这里设置了一个flag变量来判断是正数还是负数。

long long ret = 0;
while (*str != '\0')
{if (isdigit(*str)){ret = ret * 10 + (*str - '0')*flag;if (ret > INT_MAX){return INT_MAX;}if (ret < INT_MIN){return INT_MIN;}}else{return (int)ret;}str++;
}

这段代码就除开那上面那些情况来进入下一步判断,首先我们设置了一个长整形来防止整形溢出,然后进入while循环当str字符串解引用不是字符串结尾\0的时候进行,下面进入if语句如果对字符串解引用是一个数字,这里用了一个isdigit函数来判断是否为数字。

ret = ret * 10 + (*str - '0')*flag;

这是一个数学公式用来把字符123变成数字123的,假如字符1想变成数字1就那字符一减去字符0,他们之间的ascii码差值就是数字1,在下面两个if就是一种比较特殊的情况了,在atoi函数定义中如果返回的数字大于intmax和小于intmin就直接返回intmax和intmin,最后那个else就是遇到除开0到9字符遇到其他字符就直接返回了,最后str指针自增1,我们来看看开头设置的一个枚举

enum State
{VAILD,//不非法的 INVAILD//非法的
} state = INVAILD;

这里就是用来判断返回的到底是合法还是非法的,合法的就是想把字符串中所有的数字都转换完了的就相当于把字符串都遍历了一遍,字符串指针走到了字符结尾非法的就是没有遍历完,没有走到字符串结尾。这里我们首先把他赋值为非法的

if (*str == '\0')
{state = VAILD;//这里就是判断字符串指针走没走完
}
if (state == VAILD)
{printf("合法转化:%d\n", ret);
}
else
{printf("不合法转化:%d\n", ret);
}

根据返回值来判断打印。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/768748.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言数据结构之计数排序

世中逢尔 雨中逢花 目录 计数排序的介绍 代码展示 时间复杂度和空间父复杂度 计数排序的用途 计数排序的局限性 计数排序的介绍 排序原理 计数排序又称为鸽巢原理&#xff0c;是对哈希直接定址法的变形应用。 是一个不比较排序算法&#xff0c;通过计数将时间复杂度降到了O…

大型网站集群管理负载均衡

课程介绍 结合企业大规模应用&#xff0c;解决应用高并发问题&#xff0c;解决单节点故障问题&#xff0c;缓存数据库的应用。学完掌握知识点&#xff1a;企业应用实现四七层负载均衡&#xff0c;以及Nginx等应用的高可用性&#xff0c;Redis缓存数据库的部署应用以及高可用方…

【Redis】优惠券秒杀

全局唯一ID 全局唯一ID生成策略&#xff1a; UUIDRedis自增snowflake算法数据库自增 Redis自增ID策略&#xff1a;每天一个key&#xff0c;方便统计订单量ID构造是 时间戳 计数器 Component public class RedisIdWorker {// 2024的第一时刻private static final long BEGIN…

Unity 背包系统中拖拽物体到指定位置或互换位置效果的实现

在Unity中&#xff0c;背包系统是一种常见的游戏系统&#xff0c;可以用于管理和展示玩家所持有的物品、道具或装备。 其中的拖拽功能非常有意思&#xff0c;具体功能就是玩家可以通过拖拽物品图标来移动物品在背包中的位置&#xff0c;或者将物品拖拽到其他位置或界面中&…

29双体系Java学习之编程的基本过程和类的通用格式

编程的基本过程 类的通用格式 ★小贴士 类的设计应遵循单一职责原则&#xff08;SRP&#xff09;&#xff0c;即只能让一个类有且仅有一个职责&#xff0c;以保证修改的可能性尽量少。

DEll R440 LC下的硬件日志收集步骤(注意:此方法收集的日志里无操作系统的日志);

一&#xff0c; LC下的硬件日志收集步骤&#xff08;注意&#xff1a;此方法收集的日志里无操作系统的日志&#xff09;&#xff1b; 开机看到屏幕左上角出现F10的提示的时候&#xff0c;敲击F10&#xff0c;进入LC的界面&#xff1a; 找到U盘的类似文件&#xff0c;就是最终生…

无人驾驶中的坐标转换

无人驾驶中的坐标转换 无人车上拥有各种各样的传感器&#xff0c;每个传感器的安装位置和角度又不尽相同。对于传感器的提供商&#xff0c;开始并不知道传感器会以什么角度&#xff0c;安装在什么位置&#xff0c;因此只能根据传感器自身建立坐标系。无人驾驶系统是一个多传感器…

Windows/Linux-openEuler系统使用路由侠内网穿透,部署项目详细教程

文章目录 Windows/Linux-openEuler系统使用路由侠内网穿透&#xff0c;部署项目详细教程一、在windows系统下载安装路由侠并实现项目部署1、下载路由侠并注册安装到Windows系统2、点击内网映射&#xff0c;添加映射&#xff0c;注册域名前缀3、选择网站应用4、配置你想要代理项…

ubuntu上一款好用的串口工具screen

看名字&#xff0c;你猜他是什么&#xff1f; 安装 sudo apt install screen 然后将USB串口接到虚拟机&#xff0c;执行dmesg命令查看串口设备名&#xff1a; 测试&#xff1a; sudo screen /dev/ttyUSB0 115200确实很简单。

数据结构(五)——树森林

5.4 树和森林 5.4.1 树的存储结构 树的存储1&#xff1a;双亲表示法 用数组顺序存储各结点&#xff0c;每个结点中保存数据元素、指向双亲结点(父结点)的“指针” #define MAX_TREE_SIZE 100// 树的结点 typedef struct{ElemType data;int parent; }PTNode;// 树的类型 type…

【Godot4.2】像素直线画法及点求取函数

概述 基于CanvasItem提供的绘图函数进行线段绘制只需要直接调用draw_line函数就可以了。 但是对于可以保存和赋值节点直接使用的纹理图片&#xff0c;却需要依靠Image类。而Image类没有直接提供基于像素的绘图函数。只能依靠set_pixel或set_pixelv进行逐个像素的填色。 所以…

C++项目——集群聊天服务器项目(三)muduo网络库

今天来介绍集群聊天器项目中网络模块代码的核心模块——muduo网络库&#xff0c;一起来看看吧~ 环境搭建C项目——集群聊天服务器项目(一)项目介绍、环境搭建、Boost库安装、Muduo库安装、Linux与vscode配置-CSDN博客 Json第三方库C项目——集群聊天服务器项目(二)Json第三方库…

Linux的介绍以及其发展历史

文章目录 前言一、技术是推动社会发展的基本动力1.人为什么能成为万物之长呢&#xff1f;2.人为什么要发明工具&#xff0c;进行进化呢&#xff1f;3.人是如何发明工具的&#xff1f;4.为什么要有不同的岗位和行业&#xff1f; 二、计算机(操作系统)发展的基本脉络1.第一台计算…

Xilinx高级调试方法--多卡调试

Xilinx高级调试方法--多卡调试 1 测试工程2 驱动修改3 工程测试 本文主要介绍基于XVC技术实现多卡调试的方法 1 测试工程 加速卡1 Verdor ID&#xff1a;1BD4Device ID&#xff1a;903E 加速卡2 Verdor ID&#xff1a;1BD4Device ID&#xff1a;903F 2 驱动修改 为了同时识…

大数据技术原理与应用 01.大数据概述

不可以垂头丧气&#xff0c;会显矮 —— 24.3.24 参考学习&#xff1a;厦门大学 林子雨老师 大数据技术原理与应用 一、大数据时代 大数据概念、影响、应用、关键技术 大数据与云计算、物联网的关系 ①三次信息化浪潮时代 ②第三次信息化浪潮的技术支撑 1>存储设备容量不断…

ARM:按键中断

key_inc.c #include"key_inc.h"void key1_it_config(){//使能GPIOF外设时钟RCC->MP_AHB4ENSETR | (0x1<<5);//将PF9设置为输入模式GPIOF->MODER & (~(0x3<<18));//设置由PF9管脚产生EXTI9事件EXTI->EXTICR3 & (~(0XFF<<8));EXTI…

msyq类型类转换造成索引失效

今天碰到一个慢sql的问题&#xff0c;sql明明按照最前缀的原则写的&#xff0c;但是索引就是不生效&#xff0c;最终排查发现是因为索引字段发生类型转换造成的。 一、表结构 1、表字段 2、表索引 二、问题sql EXPLAIN SELECT * FROM t_res WHERE open 1 AND res_date &…

蓝桥杯day12刷题日记

P8720 [蓝桥杯 2020 省 B2] 平面切分 思路&#xff1a;首先借用dalao的图解释一下&#xff0c;又多出一条与当前平面任意一条直线都不重合线时&#xff0c;多了的平面是交点数1&#xff0c;所以用双层循环每次往里面加一条直线&#xff0c;计算交点 #include <iostream>…

Ubuntu Desktop - Updates (不升级到新版本)

Ubuntu Desktop - Updates [不升级到新版本] 1. UpdatesReferences 1. Updates System Settings -> Software & Updates -> Updates ubuntu-16.04.3-desktop-amd64.iso 不升级到新版本 ​ References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

TypeScript 常见的面试题

文章目录 1. 什么是TypeScript2. 类型声明和类型推断的区别&#xff0c;并举例应用3. 什么是接口&#xff08;interface&#xff09;&#xff0c;它的作用&#xff0c;接口的使用场景。接口和类型别名&#xff08;Type Alias&#xff09;的区别4. 什么是泛型&#xff08;generi…