-2

我偶然发现了这个奇怪的问题。

我有 2 对四个八位字节。

1) 255.255.255.0 (like a subnet mask)
2) 128.127.0.0 (fictive mask)

我的二进制表示是:

1) 11111111.11111111.11111111.00000000
2) 10000000.01111111.00000000.00000000

但从我的简单应用程序中,我得到:

1) 11111111.11111111.11111111.00000000
2) 11111110.01111111.00000000.00000000

我认为这是错误的值,但请纠正我,我认为我误解了其中的重要内容。

生成二进制表示的代码是:

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

void PrintBinary(unsigned int n)
{
    unsigned int tmp;
    int i = 1;
    tmp = n;
    do{
       printf("%d", (n & tmp) ? 1 : 0);
       if(i % 8 == 0 && i < 32)
           printf(".");
       ++i;
       n >>= 1;
      }while(n>0);
    printf("\n");
}

int main(int argc, char **argv)
{
    unsigned int octet1 = 128;
    unsigned int octet2 = 127;
    unsigned int octet3 = 0;
    unsigned int octet4 = 0;
    unsigned int a = octet1 << 24 | octet2 << 16 | octet3 << 8 | octet4;
    PrintBinary(a);
    return 0;
}
4

3 回答 3

2

你的主要问题是

tmp = n;

所以一般来说,您正在检查是否在(n & tmp) ? 1 : 0.

您的掩码应该只设置一位,并且您应该移动掩码,而不是值。

void PrintBinary(unsigned int n)
{
    unsigned int tmp = 1 << (sizeof(unsigned int) * CHAR_BIT - 1);
    int i = 1;
    do{
       printf("%d", (n & tmp) ? 1 : 0);
       if(i % 8 == 0 && i < 32)
           printf(".");
       ++i;
       tmp >>= 1;
      }while(tmp > 0);
    printf("\n");
}

应该提供所需的输出。

于 2012-10-08T19:17:20.700 回答
1

你的PrintBinary功能没有多大意义。您正在tmp用作掩码,但tmp等于n

相反,尝试类似

int i;
for(i=31; i>=0; i--) {
    printf("%d", !!(n & (1<<i)));
    if(i%8 == 0) printf(".");
}
于 2012-10-08T19:17:49.017 回答
0

尝试:

void PrintBinary(unsigned int n)
{
    unsigned int tmp = n;
    for (int i = 1; i <= 32; ++i) {
       printf("%d", (tmp & 1));
       if (i % 8 == 0)
           printf(".");
       temp >>= 1;
    }
    printf("\n");
}

如果您的终止条件为 (n > 0),则不能使用do循环,否则当该八位字节的值小于 0x80 (128) 时,您将在第一个八位字节中丢失前导零。

于 2012-10-08T19:20:28.397 回答