我正在尝试编写一个方法,该方法接受一个 32 位 int 和一个表示 32 位 int 中一个字节的整数,并返回传入的字节。即 getByte(0x56781234, 0); // => 0x34。我的思考过程是,如果我可以将 int 右移到我想要的字节是 int 的最后一个字节的位置,我可以将其与 0xFF 进行 AND 运算以获得该值。所以像,public int getByte(int num, int byteVal) { return ((num >> 8) >> byteVal) & 0xFF;}但是我知道我的逻辑是有缺陷的。我试图在一个语句中多次移动。警告:没有乘法。建议?
1 回答
www说
TA贡献1775条经验 获得超8个赞
您希望根据 byteVal 的值向右移动 0、8、16 或 24。在您的示例中,即使 byteVal 为 0,您也已经向右移动了 8,所以这不是方法。
那么,你如何将 0/1/2/3 变成 0/8/16/24 ......如果只有一个移位操作可以做到这一点!
return (num >> (byteVal << 3)) & 0xFF;
添加回答
举报
0/150
提交
取消