【问题标题】:Java: byte[] bit shift operation into shortJava: byte[] 移位操作变短
【发布时间】:2017-04-12 19:50:26
【问题描述】:

我有一个大小为 4096 的字节数组。我用 0xA2 填充字段 0,用 0xF0 填充字段 1。

我的目标是将字段 0 向左移动 8 位,然后对字段 1 进行 OR 运算并将其存储到一个短变量中。

纸上的结果应该是:

     1010 0010 (0xA2) 
>>shift left by 8 bits
1010 0010 0000 (0xA20)

>>OR-operation with field 1
1010 0010 0000 (0xA20)(field 0)
     1111 0000 (0xF0)(field 1)
----------------------
1010 1111 0010 (0xAF2)

已经有a similar post,但它只提供了一点帮助。 即使我在铸造它似乎切断了移位的位。 这是代码。

public static void main(String[] args) {
        byte[] myMem = new byte[4096];
        myMem[0] = (byte)0xA2;
        myMem[1] = (byte)0xF0;

        short test = (short)(myMem[0] << 8 | myMem[1]);
    }

调试器显示以下值:

myMem[0] = -94 (which is correctly 0xA2)
myMem[1] = -16 (which is correctly 0xF0)
test = -16 (which is wrong, 0x00A2. Should be -23824 or 0xA2F0). 

我想我在某个地方犯了一个逻辑错误,但我找不到它。

【问题讨论】:

    标签: java bit-shift


    【解决方案1】:

    使用

        short test = (short)((myMem[0]  << 8) | ((myMem[1])& 0xff));
    

    【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-11-17
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多