Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1395839
  • 博文数量: 143
  • 博客积分: 10005
  • 博客等级: 上将
  • 技术积分: 1535
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-23 17:25
个人简介

淡泊明志 宁静致远

文章分类

全部博文(143)

文章存档

2011年(2)

2009年(1)

2007年(22)

2006年(118)

我的朋友

分类: C/C++

2006-12-14 14:43:52

C语言库函数源代码】

【本程序在Dev C++ 4.9.9.2 下编译通过】

/*

   这个函数是把浮点数字符串转换为浮点数的函数。

   函数将会跳过字符串中的空格字符和不是'+'、'-'、'.'、

   数字的字符。如果字符串是空的或者都是由空格组成,将不会

   做任何转换,仅仅是把字符串的结束地址赋给endptr。如果字

   符串合法,将会进行转换,并把字符串最后的NULL的地址给

   endptr。如果你想使用endptr参数,那么赋一个NULL值就

   可以了。

*/

double my_strtod(const char* s, char** endptr)

{

   register const char*  p     = s;

    register long double  value = 0.L;

    int                   sign  = 0;

    long double           factor;

    unsigned int          expo;

  

    while ( isspace(*p) )//跳过前面的空格

      p++;

 

    if(*p == '-' || *p == '+')

      sign = *p++;//把符号赋给字符sign,指针后移。

  

   //处理数字字符

 

    while ( (unsigned int)(*p - '0') < 10u )//转换整数部分

      value = value*10 + (*p++ - '0');

   //如果是正常的表示方式(如:1234.5678)

   if ( *p == '.' )

   {

        factor = 1.;

        p++;

        while ( (unsigned int)(*p - '0') < 10u )

      {

         factor *= 0.1;

            value  += (*p++ - '0') * factor;

        }

    }

   //如果是IEEE754标准的格式(如:1.23456E+3)

    if ( (*p | 32) == 'e' )

   {

      expo   = 0;

        factor = 10.L;

        switch (*++p)

      {

        case '-':

           factor = 0.1;

        case '+':

           p++;

           break;

        case '0':

        case '1':

        case '2':

        case '3':

        case '4':

        case '5':

        case '6':

        case '7':

        case '8':

        case '9':

           break;

        default :

           value = 0.L;

           p     = s;

           goto done;

        }

        while ( (unsigned int)(*p - '0') < 10u )

            expo = 10 * expo + (*p++ - '0');

        while ( 1 )

      {

        if ( expo & 1 )

           value *= factor;

            if ( (expo >>= 1) == 0 )

                break;

            factor *= factor;

        }

    }

done:

    if ( endptr != 0 )

        *endptr = (char*)p;

 

    return (sign == '-' ? -value : value);

}

double my_atof(char *str)

{

   return my_strtod(str,0);

}

int main()

{

   char * str = "12345.6789";

   printf("%f\n",my_strtod(str,0));

   printf("%f\n",my_atof(str));

  

   str = "-12345.6789";

   printf("%f\n",my_strtod(str,0));

   printf("%f\n",my_atof(str));

 

   str = "9.8546721E+4";

   printf("%f\n",my_strtod(str,0));

   printf("%f\n",my_atof(str));

 

   str = "-985467.21e-4";

   printf("%f\n",my_strtod(str,0));

   printf("%f\n",my_atof(str));

  

   system("pause");

   return 0;

}

阅读(12529) | 评论(4) | 转发(1) |
给主人留下些什么吧!~~

jiangkai02014-05-07 09:41:38

毫无精度可言,用滚轮法是历史积累的错误

yxnyxnyxnyxn2012-03-01 13:49:26

f.u.moon: while ( 1 )      {        if ( expo & 1 )           value *= factor;            if ( (expo >>= 1) == 0 )                break;            f.....
同意,一开始都没看懂。

f.u.moon2010-11-17 11:14:53

while ( 1 ) { if ( expo & 1 ) value *= factor; if ( (expo >>= 1) == 0 ) break; factor *= factor; } 改成: while ( 0 < expo-- ) { value *= factor; } 可能可读性更好。

chinaunix网友2009-08-13 09:53:29

看似不错的函数,