2

我试图屏蔽一个整数,以便像这样单独分隔每个字节:

     int a = (0xffffffff & 0xff000000) >> 24;
     int b = (0xffffffff & 0x00ff0000) >> 16;
     int c = (0xffffffff & 0x0000ff00) >> 8;
     int d = 0xffffffff & 0x000000ff;

在这种情况下,b、c 和 d 给出了正确答案,255,但是,无论我将其更改为什么,a 都会继续给我 -1 和其他负数,我什至尝试过:

             int a = (0xefffffff & 0xff000000) >> 24;

它给了我-17。

有人知道我该如何解决这个问题,以便在这种边界情况下 a 给我 255 和其他正数?

4

3 回答 3

9

这是因为符号扩展。如果最高位为 1,则>>移位 1。这是为了保留论证的符号。您想使用>>>which 总是在 0 中移位。或者,在移位后进行掩码:

int a = (0xffffffff >> 24) & 0x000000ff;
于 2012-09-13T18:18:50.010 回答
2

你正在做一个有符号的转变,所以这个符号被保留了。

int a = (0xffffffff & 0xff000000) >>> 24; // unsigned shift.

或者

int a = 0xffffffff >>> 24; // unsigned shift and all the bottom bits are lost anyway
int b = (0xffffffff >>> 16) & 0xFF;
int c = (0xffffffff >>> 8) & 0xFF;
int d = 0xffffffff & 0xFF;
于 2012-09-13T18:20:09.010 回答
0

我认为你需要一个unsigned shifting

试试这个方法...

(0xffffffff & 0xff000000) >>> 24

于 2012-09-13T18:23:16.197 回答