2

我有以下代码:

byte[] S = new byte[256];
byte[] T = new byte[256];

for (int i = 0; i < 256; ++i) {
    S[i] = (byte)i;
    T[i] = 13;
}

int j = 0;
int i2 = 0;
while (i2 < 256) {
    j = j + S[i2] + T[i2] & 255;
    byte[] arrby = S;
    int n2 = i2;
    arrby[n2] = (byte)(arrby[n2] ^ S[j]);
    byte[] arrby2 = S;
    int n3 = j;
    arrby2[n3] = (byte)(arrby2[n3] ^ S[i2]);
    byte[] arrby3 = S;
    int n4 = i2++;
    arrby3[n4] = (byte)(arrby3[n4] ^ S[j]);
}

具有初始值的 S[] 数组:0,1,2,3,4,5...

当程序到达该行时:

arrby[n2] = (byte)(arrby[n2] ^ S[j]);

S[0] 将其值从“0”更改为“13”,我不明白为什么。什么在修改 S[0] 值?正如我所看到的,'^' 只是进行比较并更改 arrby[n2] 的值而不是 S[0] 的值

4

2 回答 2

6

这里:

byte[] arrby = S;

您正在arrby 指向与S相同的数组。

然后:

arrby[n2] = (byte)(arrby[n2] ^ S[j]);

您正在更改该数组中的条目。

田...

因此,解决方案是:如果您不想修改数组的内容,请确保不要创建指向该数组的其他引用。例如,根据您的要求,您可以先将数据从 S复制到新创建的arrby数组中。

于 2017-02-07T13:48:16.790 回答
1

下面的代码行arrby引用相同的分配内存S

byte[] arrby = S;
于 2017-02-07T13:49:04.313 回答