strtoul函数的使用

strtoul函数的使用函数原型:参数1:字符串起始地址参数2:返回字符串有效数字的结束地址,这也是为什么要用二级指针的原因。参数3:转换基数。当base=0,自动判断字符串的类型,并按10进制输出,例如"0xa

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

函数原型:

unsigned long strtoul(const char *nptr,char **endptr,int base )

参数1:字符串起始地址
参数2:返回字符串有效数字的结束地址,这也是为什么要用二级指针的原因。
参数3:转换基数。当base=0,自动判断字符串的类型,并按10进制输出,例如”0xa”,就会把字符串当做16进制处理,输出的为10。更多的下面详细阐述。

  1. static unsigned int simple_guess_base(const char *cp)  
  2. {  
  3.     if (cp[0] == ‘0’) {  
  4.         if (TOLOWER(cp[1]) == ‘x’ && isxdigit(cp[2]))  
  5.             return 16;  
  6.         else  
  7.             return 8;  
  8.     } else {  
  9.         return 10;  
  10.     }  
  11. }  
  12.   
  13. unsigned long simple_strtoul(const char *cp, char **endp, unsigned int base)  
  14. {  
  15.     unsigned long result = 0;  
  16.   
  17.     if (!base)  
  18.         base = simple_guess_base(cp);  
  19.   
  20.     if (base == 16 && cp[0] == ‘0’ && TOLOWER(cp[1]) == ‘x’)  
  21.         cp += 2;  
  22.   
  23.     while (isxdigit(*cp)) {  
  24.         unsigned int value;  
  25.   
  26.         value = isdigit(*cp) ? *cp – ‘0’ : TOLOWER(*cp) – ‘a’ + 10;  
  27.         if (value >= base)  
  28.             break;  
  29.         result = result * base + value;  
  30.         cp++;  
  31.     }  
  32.   
  33.     if (endp)  
  34.         *endp = (char *)cp;  
  35.     return result;  
  36. }  

函数分析:
1 simple_strtoul()函数里的第一个if语句,如果base=0,自动对字符串里的数字格式进行分析,并返回基数,其值可取8、16、10。第二个if语句,进一步对16进制数处理,是cp指向第三个字符。

2     while循环条件:判断是否为可处理的字符,其处理范围为‘0’-‘9’,‘a’-‘f,‘A’-‘F’。
       循环体内:如果*cp为数字则value=*cp-‘0’;如果*cp为字符value=*cp-’a‘+10。
       判断value的值,如果value>=base,表明其值超过了基数,是一个不合法的数字,跳出循环。例如基数base=3, 数码符号为0,1,2,3。 此时value=4时就不是一个数码符号。

3     处理尾指针,使其指向字符串有效数字的结束地址。

4 返回result。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/166741.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • noip2014普及组复赛题解_noip2019普及组复赛试题

    noip2014普及组复赛题解_noip2019普及组复赛试题NOIP2012普及组解题报告            byRtPYH——————————————————————————————————————前言:作者是一个蒟蒻,如果对本文有建议,欢迎提出!鄙人将虚心接受。

    2022年8月22日
    7
  • hdu1524博弈SG

    hdu1524博弈SG

    2021年8月25日
    60
  • 史上最简单的 IntelliJ IDEA 教程「建议收藏」

    史上最简单的 IntelliJ IDEA 教程「建议收藏」温馨提示:本教程的GitHub地址为「intellij-idea-tutorial」,欢迎感兴趣的童鞋Star、Fork,纠错。1简介  IntelliJIDEA(简称IDEA),是Java语言开发的集成环境,IDEA在业界被公认为最好的Java开发工具之一,尤其在智能代码助手、代码自动提示、重构、J2EE支持、各类版本工具(Git、SVN、GitHub…

    2022年6月8日
    40
  • 最好的频谱分析仪基础知识「建议收藏」

    最好的频谱分析仪基础知识「建议收藏」转载自网优雇佣军文章目录最好的频谱分析仪基础知识前言有两种技术方法可完成信号频域测量(统称为频谱分析)。快速傅立叶变换频谱分析仪扫频式频谱分析仪工作原理输入衰减器混频器中频滤波器对数放大器检波器视频滤波器扫描本振频谱分析仪关键性能指标频率分辨率相位噪声灵敏度总结一下提高频谱仪测试灵敏度的技术方法:最好的频谱分析仪基础知识前言频谱分析是观察和测量信号幅度和信号失真的一种快速方法,其显示结果可…

    2022年8月11日
    5
  • java 实现 按位异或_转:[Java] 深入理解按位异或运算符

    java 实现 按位异或_转:[Java] 深入理解按位异或运算符转自:参与运算的两个值,如果两个相应bit位相同,则结果为0,否则为1。即:0^0=0,1^0=1,0^1=1,1^1=0例如:10100001^00010001=10110000按位异或的3个特点:(1)0^0=0,0^1=10异或任何数=任何数(2)1^0=1,1^1=01异或任何数-任何数取反(3)任何数异或自己=把自己置0按位异或的几…

    2022年6月5日
    27
  • c# 字典树_c++树的遍历

    c# 字典树_c++树的遍历c#入门Trie基于SortedDictionary添加查询非递归实现递归实现前缀基于SortedDictionary添加查询非递归实现递归实现前缀publicclassTrie{privateclassNode{publicboolIsWord;publicSortedDictionary<char,Node>Next;publicNode(boolisWord)

    2025年8月29日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号