猿问

在一个语句中多次按位移位

我正在尝试编写一个方法,该方法接受一个 32 位 int 和一个表示 32 位 int 中一个字节的整数,并返回传入的字节。即 getByte(0x56781234, 0); // => 0x34。我的思考过程是,如果我可以将 int 右移到我想要的字节是 int 的最后一个字节的位置,我可以将其与 0xFF 进行 AND 运算以获得该值。所以像,


public int getByte(int num, int byteVal) {

    return ((num >> 8) >> byteVal) & 0xFF;

}

但是我知道我的逻辑是有缺陷的。我试图在一个语句中多次移动。警告:没有乘法。建议?


慕容3067478
浏览 131回答 1
1回答

www说

您希望根据 byteVal 的值向右移动 0、8、16 或 24。在您的示例中,即使 byteVal 为 0,您也已经向右移动了 8,所以这不是方法。那么,你如何将 0/1/2/3 变成 0/8/16/24 ......如果只有一个移位操作可以做到这一点!return&nbsp;(num&nbsp;>>&nbsp;(byteVal&nbsp;<<&nbsp;3))&nbsp;&&nbsp;0xFF;
随时随地看视频慕课网APP

相关分类

Java
我要回答