我正在使用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);
}
答案 0 :(得分:2)
问题在这里:
for (i = 23; i <= 26; i++)
{
printf("%d", s[i] - '0');
hex[i] = s[i] - '0';
}
hex
索引从0
到3
,因此分配给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 来检测您的内存问题,我用它来回答您