2

到目前为止,我有这个代码来创建 16 位掩码。但是我不知道如何使用这种方法创建一个 32 位掩码。有任何想法吗?

编辑:我想创建 32 个 32 位掩码,每个掩码各自的位为 1,其余位为零。例如:掩码 1 的最左边位为 1,其余位为零,掩码 2 的最左边第二位为 1,其余位为零。我不知道如何更简洁地解释,但我希望你们明白......

mask = new int[16];
mask[0] = 0x8000;
mask[1] = 0x4000;
mask[2] = 0x2000;
mask[3] = 0x1000;

mask[4] = 0x0800;
mask[5] = 0x0400;
mask[6] = 0x0200;
mask[7] = 0x0100;

mask[8] = 0x0080;
mask[9] = 0x0040;
mask[10] = 0x0020;
mask[11] = 0x0010;

mask[12] = 0x0008;
mask[13] = 0x0004;
mask[14] = 0x0002;
mask[15] = 0x0001
4

2 回答 2

7

这是在 Java 中创建 32 位掩码的方法。

int mask = 0x00010000;  // for example.

如果你想创建一个设置了位 N 的 32 位掩码,那么

int mask = 1 << N;  // Assumes the rightmost bit is numbered zero ...

如果你想创建一个掩码数组,那么只需以明显的方式循环执行上述操作。

int[] masks = new int[32];
for (int n = 0; n < 32; n++) {
    masks[n] = 1 << n;
}

实际上,您所谓的“16 位掩码”也是 32 位掩码,因为int它是 Java 中的 32 位类型。

和@Matt Ball 一样,我对您真正想要做什么感到困惑,以及您是否要这样做是实现它的明智方式。当您可以用更少的代码动态创建掩码时,为什么需要一组掩码?

于 2013-11-10T06:50:29.753 回答
-3

我认为你做得很好。

AMOUNT_OF_BITS = 32;
mask = new long[AMOUNT_OF_BITS];
for (long i = 0; i < AMOUNT_OF_BITS; i++)
{
    mask[i] = Math.pow(2,i);
}

我认为这应该有效。

于 2013-11-10T06:51:33.760 回答