0

我正在尝试在 java 中执行一些数学计算,但没有得到预期的结果。由于当我在“C”程序中运行相同的代码片段时,它可以正常工作,请指导我代码中出了什么问题。

传递给函数的值是。

v0=1970012 and v1=1970012 and iterations= 32 

“C”程序片段看起来像这样

void encipher(uint8_t iterations, uint32_t v0, uint32_t v1)
{
    uint8_t i;

     int key[]={0x02a4bd14,0x6c753bde,0x4ac819ad,0x6da4a0c4};




     uint32_t sum, delta;

      sum=0x32d61b8e;
       delta=0x9E3779B9;
      for (i=0; i < iterations; i++) {
      v0 += (((v1 << 4) ^ (v1 >> 5)) + v1) ^ (sum + key[sum & 3]);
      sum += delta;
       v1 += (((v0 << 4) ^ (v0 >> 5)) + v0) ^ (sum + key[(sum>>11) & 3]);
   }
      en_result0=v0; en_result1=v1;
 } 

en_result0 和 en_result1 是全局变量,与 v0 和 v1 的类型相同

类似地,Java 片段代码看起来像这样。

public static void encipher(int iterations, int v0, int v1)
 {
     int i;
int key[]={0x02a4bd14,0x6c753bde,0x4ac819ad,0x6da4a0c4};
     int sum, delta;
     sum=0x32d61b8e;
      delta=0x9E3779B9;
  for (i=0; i < iterations; i++) {
   v0 += (((v1 << 4) ^ (v1 >> 5)) + v1) ^ (sum + key[sum & 3]);
   sum += delta;
   v1 += (((v0 << 4) ^ (v0 >> 5)) + v0) ^ (sum + key[(sum>>11) & 3]);
  }
  en_result0=v0; en_result1=v1;

}

这里 en_result0 和 en_result1 也是 int 类型的全局变量

The answer in "C" programme en_result0=3755627302 and en_result1=3278396279 

The Answer in "java" Programme en_result0=-1152914223 and en_result1=1706153302

只是没有找到哪里出错了请帮我找到解决方案

4

3 回答 3

3

当您将 >> 运算符替换为 Java 的 >>> 运算符时,您应该会得到正确的结果。它执行无符号右移,这正是 C 代码通过声明无符号变量和执行右移所实现的。

其他操作是无害的并且给出相同的结果,无论是签名还是未签名。

请注意,要打印结果,您应该执行以下操作:

println( ((long) result) & 0xFFFFFFFFL ); // where result is int

或使用适当的 printf 格式(即以十六进制打印)。

于 2013-09-25T11:55:29.203 回答
2

一个问题是 C 代码使用无符号整数类型,而 Java 代码使用有符号类型(Java 中没有无符号整数)。

一种可能性是使用 Javalong代替uint32_tC。它已签名,但宽度是原来的两倍。您可能还需要更改 、 和 的类型,以v0避免整数溢出。v1en_result0en_result1

于 2013-09-25T11:41:49.100 回答
0

这是因为java中整数的取值范围。

int 数据类型是一个 32 位有符号二进制补码整数。最小值 > -2,147,483,648,最大值为 2,147,483,647(含)

使用 along而不是int

于 2013-09-25T11:43:18.950 回答