内存分配和泄漏问题?

时间:2019-05-06 16:21:20

标签: c memory-management memory-leaks malloc

我正在使用print_selected(int x)函数,该函数需要x然后提取比特5、6、7和8(从最右边的比特0开始) 然后将它们打印在两个二进制文件中,然后以十六进制打印。

有一个辅助函数,int2bin(int n)中的print_selected(int x)int2bin(int)函数将一个char类型的数组返回到s

问题是我可以正确打印出5、6、7和8位的二进制数,但是十六进制数会以某种方式返回怪异的数字(由于内存泄漏问题?)。 我强烈怀疑char* s = int2bin(x)中的free(s)print_selected(int)可能是问题,但我不知道应该更改哪一部分以正确打印正确的十六进制数。

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

// takes integer and returns char array with 32 binary number.
char* int2bin(int n)  
{
    int nbits = sizeof(n) * 8;
    char *s = malloc(nbits + 1);

    s[nbits] = '\0';

    unsigned int u = *(unsigned int*)&n;
    int i;
    unsigned int mask = 1 << (nbits - 1);
    for (i = 0; i < nbits; i++, mask >>= 1)
        s[i] = ((u & mask) != 0) + '0';
    return s;
}

// takes an integer and print in "binary" and "hexadecimal".
void print_selected(int x) 
{
    int hex[4];  // to store the 4 bits of (5,6,7,8) 
    int i;

    char *s = int2bin(x); //  I think this part makes problem?

    printf("bits 5 to 8 in bin: ");
    for (i = 23; i <= 26; i++)
    {
        printf("%d", s[i] - '0');
        hex[i] = s[i] - '0';
    }

    free(s); // I think this part makes problem?

    printf("\n");

    int j = 3; // since we already know the number of bits,
    int sum = 0;

    for (i = 0; i <= 3; i++)
    {
        sum = sum + (hex[i] * pow(2, j));
        j--;
    }

    printf("in hex: 0x%x\n", sum);
}

int main(void)
{
    int a = 278;
    print_selected(a);
}

2 个答案:

答案 0 :(得分:2)

问题在这里:

    for (i = 23; i <= 26; i++)
    {
        printf("%d", s[i] - '0');
        hex[i] = s[i] - '0';
    }

hex索引从03,因此分配给hex[23]会导致未定义的行为。然后,您尝试打印从未真正填写过的hex元素。

您需要:

hex[i - 23] = s[i] - '0';

答案 1 :(得分:2)

  

但是,十六进制数返回某种奇怪的数字(由于内存泄漏问题?)。

否,您将访问未初始化的内存

for (i = 0; i <= 3; i++)
{
    sum = sum + (hex[i] * pow(2, j));
    j--;
}

因为十六进制仅在

中初始化
for (i = 23; i <= 26; i++)
{
   printf("%d", s[i] - '0');
   hex[i] = s[i] - '0';
}

对于索引23到26,而不是索引0到3

请注意,您还用 hex 写出了未定义的行为,您需要使用索引i -23来编写 hex

所以 sum 的值未定义

我鼓励您使用 valgrind 来检测您的内存问题,我用它来回答您