码迷,mamicode.com
首页 > 其他好文 > 详细

strtoul函数的使用,揭开其神秘面纱

时间:2017-10-23 20:01:05      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:tar   lower   sim   types   base   原型   rto   key   pre   

函数原型:

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。

strtoul函数的使用,揭开其神秘面纱

标签:tar   lower   sim   types   base   原型   rto   key   pre   

原文地址:http://www.cnblogs.com/Caden-liu8888/p/7718474.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!