CE60下的atof实现分析和总结.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
WinCE6.0 下字符串转换为浮点数 SUNNY.MAN 平时把字符串转换为浮点数,就用atof 或是_tstof,但一运行才发现 atof 或是_tstof 居然都不可用。出现如下提示错误:errorC3861:_tstof:identifiernot found.百思不得其解,加上了#include”TCHAR.H”居然还是不行。于是我个人以为一定是 OS 版本的问题,也许通过其它头文件的引用,或许可以在CE6.0 下使用,但我简单的百度了一下,没有发现方法。也不是一个特别复杂的函数, 没有继续找答案,自己动手写了一个 myatof 来实现这个功能。 要写这个函数,主要考虑以下几个方面: 正负数 是否数字和数字截断 科学计数法的支持 有效数字的算法 溢出的考虑。 闲话少数,直接上代码,在代码中加入 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) { } else { } bHaveradixpoint=TRUE; break; } else//其它各种符号都返回 { } }//for break; } fRes=fRes+fDemic/nDecimalCount; fRes*=pow((double)10,nEcount); if(bIsNegative) { fRes*=-1; } } return fRes; } 最终测试下列结果,两者完全一至: float f=myatof(L-3.5e2); float f1=atof(-3.5e2); float f=myatof(Lasdfasd); float f1=atof(asdfasd); float f=myatof(L1234567890); float f1=atof(1234567890); float f=myatof(L

您可能关注的文档

文档评论(0)

tianya189 + 关注
官方认证
文档贡献者

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

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档