将小数转换为指数和尾数

时间:2013-03-30 06:16:45

标签: c

我正在尝试将十进制数字(329.39062)转换为二进制数(指数,指代符号)。我一直在分段错误。在运行gdb测试时,它向我显示了这一点。我已经改变了很多,但它在同一点上不断向我显示分段错误。我哪里错了?谢谢你的帮助。

#include <stdio.h>
#include <stdlib.h>

char* valueToConvert(int value);

int main(int argc, char *argv[])
{
        FILE* input;
        FILE* output;

        input = fopen(argv[1],"r");
        output = fopen(argv[2],"w");

    float value;
    unsigned char *charValue = (unsigned char *) &value;
    int exponentValue;
    long mantissaValue;

    while(!feof(input))
    {
        fread(&charValue, sizeof(float),1, input);
        exponentValue = ((charValue[0] & 0x7F) << 1)|((charValue[1] & 0x80) >> 7);  
        mantissaValue = ((charValue[1] & 0x7F) << 8)|((charValue[2] & 0xFF) <<8) | (charValue[3] & 0xFF);
        fprintf(output,"%d %s %s\n",(charValue[0] & 0x80 >> 7),valueToConvert(exponentValue - 127),valueToConvert(mantissaValue));
    }
}

char* valueToConvert(int value)
{
    int counter = 0;
    char* conversion = calloc(32,sizeof(int));
    while(value>0)
    {
        if((value%2 == 1) && (value%2 != 0))
        {
            conversion[31 - counter++] = '1';
        }
        if((value%2 == 0) && (value%2 != 1))
        {
            conversion[31 - counter++] = '0';
        }
        value = value/2;
    }
    return conversion;
}

1 个答案:

答案 0 :(得分:1)

问题在于:

fread(&charValue, sizeof(float),1, input);

那应该是

fread(charValue, sizeof(float),1, input);

因为charValue是指针。


要解决输出问题,在0通过calloc完全初始化缓冲区之后,您将向后填充缓冲区,因此fprintf正在点击0(a char用于表示字符串的结尾)并“过早地”停止。

这是一个快速的二进制字符串函数:

void fast_d2b(int x, char* c) {
    int i;
    for (i = 31; i >= 0; --i) {
        *(c++) = '0' + ((x >> i) & 0x1);
    }
}

它基于显示的here。 唯一的区别是我的变体不会向后写入缓冲区,而是写入'0''1'而不是整数值01