浮点数在串口打印的函数

/********************************************************************************************************
网上的浮点数在串口打印的函数都不太完美,于是参考他们的一些算法自己写了一个比较完善的算法
可以完成包括负数和正数的浮点数转字符串的转换
****************************************************************************************************/

#include<stdio.h>
typedef unsignedchar uint8;
typedef unsignedint uint32;


uint8Float2Char(float value,uint8 *array);


void main()
{
    uint8A[10];
    floatvalue= -123.456789;
    uint8i;
   Float2Char(value,A);
   printf("%s",A);
}


uint8Float2Char(float value,uint8 *array)
{
   floatDecimalPart;
   uint32IntegerPart;
   uint8i = 0, j = 0, temp;
   //分离整数和小数
    if(value< 0)

    {
       value = -value ;
       array[i++] = '-';
    }
    else
       array[i++] = '+';
   IntegerPart = (uint32)value;
   DecimalPart =  value - IntegerPart;
    //处理整数
    if(0== IntegerPart)//
整数部分为0
       array[i++] = '0';

    else
    {
       while(0 != IntegerPart)
       {
           array[i++ ] = IntegerPart%10 + '0';
           IntegerPart/=10;
       }
       i --;
       for(j = 1; j < (i+1)/2; j++)
           {
               temp = array[j];
               array[j] = array[i -j+1];
               array[i-j+1] = temp;
           }
       i++;
    }


   array[i++] = '.';
   //处理小数
  array[i++] = (uint32)(DecimalPart * 10)%10 + '0';

  array[i++] = (uint32)(DecimalPart * 100)%10 + '0';
   array[i++]= (uint32)(DecimalPart * 1000)%10 + '0';
  array[i++] = (uint32)(DecimalPart * 10000)%10 + '0';
  array[i]   = '\0';
   returni;
}

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Keil中使用串口打印浮点数,可以按照以下步骤进行操作: 1. 配置串口:在Keil中,首先需要配置正确的串口参数,包括波特率、数据位、停止位和校验位等。这通常通过对串口寄存器进行相应的设置来完成。 2. 引入必要的头文件:在代码中引入必要的头文件,包括用于串口通信的头文件和浮点数处理的头文件。 ```c #include <stdio.h> // 用于格式化输出 #include <stdint.h> // 用于定义整数类型 #include <math.h> // 用于浮点数处理 ``` 3. 使用printf函数打印浮点数:Keil提供了标准库函数printf,可以用于格式化输出浮点数。 ```c float num = 3.14; printf("The float number is %.2f\n", num); ``` 在上面的示例中,%.2f表示打印浮点数并保留两位小数。 4. 配置串口输出:在Keil的工程设置中,确保正确配置了串口作为标准输出设备。这通常涉及指定正确的设备、引脚和相关的参数设置。 5. 连接并打开串口:确保将串口连接到适当的设备,并在程序开始时打开串口。 完成上述步骤后,浮点数将通过串口打印输出。 需要注意的是,某些嵌入式系统可能不支持直接打印浮点数,或者可能需要额外的库支持。在这种情况下,您可以考虑使用浮点数转换为字符串的方法,然后通过串口输出字符串来实现浮点数打印。 ```c float num = 3.14; char buffer[20]; sprintf(buffer, "The float number is %.2f\n", num); printf("%s", buffer); ``` 上述代码中,sprintf函数浮点数转换为字符串,并将结果存储在buffer中,然后通过printf函数打印字符串。 请注意,使用浮点数可能会增加代码大小和执行时间。在嵌入式系统中,如果资源有限或对性能要求较高,建议慎重使用浮点数操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值