从float转换为char数组

时间:2016-01-12 09:34:18

标签: c arrays floating-point embedded microcontroller

我需要将float(传感器)值转换为char数组,以便通过GPRS发送数据。如果我使用任何库函数进行转换,则会占用大量内存,因为控制器的闪存量较少。我已经尽力在没有库函数的情况下转换数据,但最后它强制需要 math.h 文件。如何在没有任何库函数的情况下解决此问题?

#include <stdio.h>
#include <string.h>
#include <math.h>
unsigned char str[20];
unsigned char *ftos(float f,int precision)
{
    memset(str,0,sizeof(str));
    float ff;
    ff = f;
    int a,b,c,k,l=0,m,i=0;
    // check for negetive float
    if(f<0.0)
    {
        str[i++]='-';
        f*=-1;
    }
    a=f;    // extracting whole number
    f-=a;   // extracting decimal part
    k = precision;
    // number of digits in whole number
    while(k>0)
    {
        l = pow(10,k);
        m = a/l;
        if(m>0)
        {
            break;
        }
    k--;
    }
    // number of digits in whole number are k+1

    /*
    extracting most significant digit i.e. right most digit , and concatenating to string
    obtained as quotient by dividing number by 10^k where k = (number of digit -1)
    */
    for(l=k+1;l>0;l--)
    {
        b = pow(10,l-1);
        c = a/b;
        str[i++]=c+48;
        a%=b;
    }
    str[i++] = '.';
    /* extracting decimal digits till precision */
    for(l=0;l<precision;l++)
    {
        f*=10.0;
        b = f;
        str[i++]=b+48;
        f-=b;
    }
    str[i]='\0';
    return str;
}

int main()
{
    float temp = 35.2;
    printf("%s",ftos(temp,2));
}  

1 个答案:

答案 0 :(得分:1)

不要尝试打印浮点值,而是打印固定点值。例如,这会打印x的值,小数点后面有2位数字:

int main()
{
    float x = 35.2;
    printf("%d.%02d\n", (int)x, (int)(x * 100) - (int)x * 100);
}

如果您需要将值实际转换为char数组,请使用sprintf而不是printf。在乘法时要小心避免整数溢出,特别是如果您的平台具有16位整数:如果需要,请使用long值。

总的来说,从微控制器C代码打印浮点数是一个好主意的情况非常少。