浮点数转换为字符串.docxVIP

  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文档。上传文档
查看更多
  串口通讯中传递的数据格式不外两种:ASCII码(即可见字符形式)和二进制数据格式(对应Modbus协议中有ASCII模式和RTU模式)。最初的想法是把浮点数的各位分别提取出来,保存成一个各元素都是ASCII码的数组,然后通过串口发送出去,对方接收到这个数组后再相应地组合成原来的浮点数。这是以前写过的一段代码:  //################################################################  // 函数名:void Float2Char(float Value,char *array)  // 描述:将浮点数的各个位的数值转换成字符串,通过串口发送至上位机显示  // 参数:float Value为欲转换的正数浮点数值,转换结果保存在字符数组*array里  //################################################################    void Float2Char(float Value,char *array)?  {   Uint16 IntegerPart;   float DecimalPart;   Uint16 i = 0;   Uint16 j = 0;   char temp;     //分离整数部分与小数部分:   //整数部分保存在IntegerPart中   //小数部分保存在DecimalPart中   if (Value=1)   {   IntegerPart = (Uint16)Value;   DecimalPart = Value-IntegerPart;   }   else?   {   IntegerPart = 0;   DecimalPart = Value-IntegerPart;   }       //转换整数部分   if (IntegerPart == 0)   {   array[0] = 0+48;   array[1] = .;   i = 1;   }   else   {   while(IntegerPart0)   {   array[i] = IntegerPart%10+48;   IntegerPart = IntegerPart/10;   i++;   }   i--;     //修正转换结果的顺序   for (j=0;j+1=(i+1)/2;j++) {   temp = array[j];   array[j] = array[i-j];   array[i-j] = temp;   }   i++;   array[i] = .;   }       //转换小数部分,此处设置最多转换到第四位小数   i++;   array[i++] = (Uint16)(DecimalPart*10)%10+48;   array[i++] = (Uint16)(DecimalPart*100)%10+48;   array[i++] = (Uint16)(DecimalPart*1000)%10+48;  // if (5 == i)   array[i++] = (Uint16)(DecimalPart*10000)%10+48;     array[i] = \0; //结束符    }?  // End of line  这段代码没有考虑负数的转换,要转换带符号数只需加入符号判断后将正(负)号标志放在数组的第一位即可。这段函数用起来挺好用,但是这种方法有很多不完善的地方,比如要预先设置字符数组*array的大小以足够存储转换后的各位,小数点位置不确定,给接收方还原数据带来了麻烦。    硬件存储浮点数,统一的标准是IEEE754标准,因此更好的方法是通过这个统一的标准来实现串口传送浮点数据的转换和还原。嵌入式硬件使用的float型数据即单精度32位浮点数格式,这在一般应用中已经足够。IEEE754规定了32位数据的格式,分别规定1位符号位、23位尾数位和8位指数位(不知有没有记错?)。比如浮点数34.9,IEEE754标准十六进制显示是0x42 0x0B 0x99 0x9A,二进制显示则是 000010111001100110011010。我最初的想法是根据这个标准规定的各部分位数,写出转换和还原的代码来;但这样确实太麻烦了。因此何妨直接借助编译器来实现这个转换??这样多方便啊  以下的代码我没有直接写,直接借用了这篇博客文章(/s/blog_4b94ff130100ejyb.html)里的程序:  /*******************************************  函数名称:F

文档评论(0)

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

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

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档