gpt4 book ai didi

java - 在 Java 中移动位的有效方法

转载 作者:行者123 更新时间:2023-11-29 05:45:01 25 4
gpt4 key购买 nike

我正在为学校做作业,我得到了奇怪的输出。所以,我想我应该先检查一些更基本的方法,然后再使用更高级的方法。我的问题是:方法会不会

public static short get16(byte a, byte b){  
return (short)(a*Math.pow(2,8)+b)
}

返回一个 short,其中前 8 位是字节 a,后 8 位是字节 b?我不明白为什么它不会,因为乘以 2^8 与向左左移 8 位相同。添加第二个字节将弥补通过乘以 2^8 获得的 8 个 0。这是正确的吗?

最佳答案

我不建议使用 Math.pow 来计算 256。众所周知,pow 很难正确实现;一些现存的实现甚至没有得到正确的确切案例!

此外,Java 中的 byte 是有符号的,因此您可能想说 (a&255)(b&255) 而不仅仅是 ab。符号扩展会毁了你的一切。

关于java - 在 Java 中移动位的有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16141325/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com