我正在用Java实现一个Skein散列函数,我遇到了一个问题,其中一些加法的模数是2^64。据我所知,在java中,long的最大值= 2^63-1。所以我的问题是,如何实现这种模运算。( Skein中的所有操作都是针对64位字的。)
发布于 2012-01-21 22:45:43
Java中的long是64位的,所以所有的操作都已经是mod 2^64了。你不需要做任何额外的事情来实现这一点。
问题是你不知道如何处理有符号的值吗?
这是你想要的东西,还是你试图避免的东西?
发布于 2012-01-21 22:40:19
BigInteger是这样做的一种方式。
发布于 2012-01-21 23:32:43
除了彼得的回答之外,我还想建议你看看这个很棒的Guava库。它有一个类UnsignedLongs,它提供了几个实用函数来处理长整型,并将它们视为无符号的。这可能会对你有所帮助。
https://stackoverflow.com/questions/8953788
复制相似问题