CE6.0下的atof实现.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CE6.0下的atof实现

WinCE 6.0下字符串转换为浮点数 SUNNY.MAN 平时把字符串转换为浮点数,就用atof或是_tstof,但一运行才发现atof或是_tstof居然都不可用。出现如下提示错误:error C3861: _tstof: identifier not found.百思不得其解,加上了#include”TCHAR.H”居然还是不行。于是我个人以为一定是OS版本的问题,也许通过其它头文件的引用,或许可以在CE6.0下使用,但我简单的百度了一下,没有发现方法。也不是一个特别复杂的函数,没有继续找答案,自己动手写了一个myatof来实现这个功能。 要写这个函数,主要考虑以下几个方面: 1.正负数 2.是否数字和数字截断 3.科学计数法的支持 4.有效数字的算法 5.溢出的考虑。 闲话少数,直接上代码,在代码中加入comment来说明自己的想法。在这里特别要提一下的是”23.567”,这后面的”0.567”。最初我的想法是5/10+6/100+7/1000。但真正的把这个写代码实现才发现,由于计算机中的小数是用逼进法表示(x*0.5+ x*0.25+ x*0.125+ x*0.0625...其中X代表每一个二进制小数位),所以会损失精度,最后的结果就会相差很多。最终采用567/1000,这样的算法。这也会损失精度,但只在最后一位损失,并且和浮点数的损失是一样的,也就是最终结果和atof一样。至于溢出和非数就交给计算机自已处理浮点数的方法。 float myatof(TCHAR * str) //输入的是一个以NULL结尾的字符串指针 { float fRes=0;//整数部分 if(str) //指针不为空 { float fDemic=0;//小数部分 int nDecimalCount=1;//小数位数*10 int nLen=_tcslen(str);//总共长度 if(nLen30) nLen=30; //再多位数考虑没有意义故从30位截 BOOL bExponential=FALSE;//是否科学记数法的指数E BOOL bHaveradixpoint=FALSE;//是否有小数点, 并且控制只能有一个 BOOL bIsNegative=FALSE;//是否负数 double nEcount=0;//e后面的10的幂次值 for(int n=0;nnLen;n++) { int nValue=str[n]-_T(0);//是否为数字 if(nValue0 || nValue9) { nValue=-1; } if(nValue!=-1)//如果是数字 { if(!bExponential)//如果不是科学计数法 { if(!bHaveradixpoint) { fRes=fRes*10+nValue; } else { fDemic=fDemic*10+nValue; //不采用下面的方法,是/10+3/100!=0.23 //float ftemp=nValue; // fRes=fRes+ftemp/nDecimalCount;; //所以采用/100,它也不一定等于.23但确保等于.29-0.2999之间。 nDecimalCount*=10; } } else//是指数 { nEcount=nEcount*10+nValue; } } else//如果不是数字 { if(str[n]==_T(E) || str[n]==_T(e)) { if(bExponential)//已经有一个E了 break; bExponential=TRUE; } else if(n==0 str[n]==_T(-))//如果是-号,并且只能在第一位 { bIsNegative=TRUE; } else if(str[n]==_T(.)) { if(bHaveradixpoint==FALSE) { bHaveradixpoint=TRUE; } else { break; } } else//其它各种符号都返回 { break; } } }//for fRes=

文档评论(0)

cgtk187 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档