atoi 与 itoa的详解和实现源代码

2024-04-04 14:58

本文主要是介绍atoi 与 itoa的详解和实现源代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一)C语言库函数名: int atoi(const char *nptr);

①函数解释

功 能: 把字符串转换成整型数.
名字来源:array to integer 的缩写.
函数说明: 参数nptr字符串,如果第一个非空格字符不存在或者不是数字也不是正负号则返回零,否则开始做类型转换,之后检测到非数字(包括结束符 \0) 字符时停止转换,返回整型数。
头文件: #include <stdlib.h>

②使用例子:

#include <stdio.h>
#include <stdlib.h>
int main(void)
{int n;char *str = "12345.67";n = atoi(str);printf("string = %s integer = %d\n", str, n);char a[] = "-100" ;char b[] = "123" ;int c = atoi( a ) + atoi( b ) ;printf("c = %d\n", c) ;return 0;
}
//执行结果
//string = 12345.67 integer = 12345
//c = 23

③实现atoi()和atol ()的源代码(32位机器):

Nginx实现

ngx_int_t
ngx_atoi(u_char *line, size_t n)
{ngx_int_t  value;if (n == 0) {return NGX_ERROR;}for (value = 0; n--; line++) {if (*line < '0' || *line > '9') {return NGX_ERROR;}value = value * 10 + (*line - '0');}if (value < 0) {return NGX_ERROR;} else {return value;}}
#include <cruntime.h>
#include <stdlib.h>
#include <ctype.h>
/***
*long atol(char *nptr) - Convert string to long
*
*Purpose:
* Converts ASCII string pointed to by nptr to binary.
* Overflow is not detected.
*
*Entry:
* nptr = ptr to string to convert
*
*Exit:
* return long int value of the string
*
*Exceptions:
* None - overflow is not detected.
*
*******************************************************************************/
long __cdecl atol(const char *nptr)
{int c; /* current char */long total; /* current total */int sign; /* if ''-'', then negative, otherwise positive *//* skip whitespace */while ( isspace((int)(unsigned char)*nptr) )++nptr;c = (int)(unsigned char)*nptr++;sign = c; /* save sign indication */if (c == '-' || c == '+')c = (int)(unsigned char)*nptr++; /* skip sign */total = 0;while (isdigit(c)) {total = 10 * total + (c - '0'); /* accumulate digit */c = (int)(unsigned char)*nptr++; /* get next char */}if (sign == '-')return -total;elsereturn total; /* return result, negated if necessary */
}
int __cdecl atoi(const char *nptr)
{return (int)atol(nptr);
}

说明:atol()只转换ASCII的数字,所以每次取下一字符时指针移动8位,传入的指针用const char有一部分原因是习惯问题;转换为unsigned char是因为ASCII字符是从0x0~0xff而没有负的,转换为int防止编译器的不同,自动转换的结果不同;、

自己实现的isdigit()函数:

inline int isdigit(unsigned char ch)
{const int m_nData = (int)(unsigned char)(ch - '0');if((m_nData >= 0) && (m_nData <=9))return m_nData;elsereturn 0;
}

//溢出的现象:

// overflow  if(total > std::numeric_limits<int>::max()){total = 0;break;}

Microsoft:

isspace(int x)    
{    if(x==' '||x=='/t'||x=='/n'||x=='/f'||x=='/b'||x=='/r')    return 1;    else     return 0;    
}    isdigit(int x)    
{    if(x<='9'&&x>='0')             return 1;     else     return 0;    
}   

在64位机器上的实现:

#ifndef _NO_INT64
__int64 __cdecl _atoi64(const char *nptr)
{int c;__int64 total;int sign;while ( isspace((int)(unsigned char)*nptr) )++nptr;c = (int)(unsigned char)*nptr++;sign = c;if (c == ''-'' || c == ''+'')c = (int)(unsigned char)*nptr++;total = 0;while (isdigit(c)) {total = 10 * total + (c - ''0'');c = (int)(unsigned char)*nptr++;}if (sign == ''-'')return -total;elsereturn total;
}
#endif

二)C语言库函数名:char *itoa(int value, char *string, int radix);

①函数解释:

参数说明:int value 被转换的整数,char *string 转换后储存的字符数组,int radix 转换进制数,如2,8,10,16 进制等。

返回值:指向string这个字符串的指针
②使用例子:

#include <stdlib.h>
#include <stdio.h>
int main(void)
{int number = 12345;char string[25];itoa(number, string, 10); //按十进制转换printf("integer = %d string = %s\n", number, string);itoa(number, string, 16); //按16进制转换printf("integer = %d string = %s\n", number, string);return 0;
}
//输出结果:
//integer = 12345 string = 12345 --说明12345的十进制表示就是12345
//integer = 12345 string = 3039 ——说明12345的十六进制表示是0x3039

③实现itoa和ltoa ()的源代码:

char* itoa(int value, char* string, int radix)
{char tmp[33];char* tp = tmp;int i;unsigned v;int sign;char* sp;if (radix > 36 || radix <= 1){//__set_errno(EDOM);return 0;}sign = (radix == 10 && value < 0);if (sign)v = -value;elsev = (unsigned)value;while (v || tp == tmp){i = v % radix;v = v / radix;if (i < 10)*tp++ = i + '0';else*tp++ = i + 'a' - 10;}if (string == 0)string = (char*)malloc((tp-tmp)+sign+1);sp = string;if (sign)*sp++ = '-';while (tp > tmp)*sp++ = *--tp;*sp = '\0';return string;
} 

补充的部分:

itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf.

char str[255];
sprintf(str, "%x", 100); //将100转为16进制表示的字符串
另外常见的相关函数有:

atol();//实现从字符串转换到长整型
ltoa(); //将长整型值转换为字符串
ultoa();// 将无符号长整型值转换为字符串



这篇关于atoi 与 itoa的详解和实现源代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/876090

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)