Give C# ByteString a sensible GetHashCode implementation.

Fixes #2511.
This commit is contained in:
Jon Skeet 2016-12-16 10:42:13 +00:00 committed by Jon Skeet
parent a95e38ce8d
commit b18bc9b944
2 changed files with 14 additions and 1 deletions

View File

@ -167,5 +167,18 @@ namespace Google.Protobuf
// Optimization which also fixes issue 61. // Optimization which also fixes issue 61.
Assert.AreSame(ByteString.Empty, ByteString.FromBase64("")); Assert.AreSame(ByteString.Empty, ByteString.FromBase64(""));
} }
[Test]
public void GetHashCode_Regression()
{
// We used to have an awful hash algorithm where only the last four
// bytes were relevant. This is a regression test for
// https://github.com/google/protobuf/issues/2511
ByteString b1 = ByteString.CopyFrom(100, 1, 2, 3, 4);
ByteString b2 = ByteString.CopyFrom(200, 1, 2, 3, 4);
Assert.AreNotEqual(b1.GetHashCode(), b2.GetHashCode());
}
} }
} }

View File

@ -303,7 +303,7 @@ namespace Google.Protobuf
int ret = 23; int ret = 23;
foreach (byte b in bytes) foreach (byte b in bytes)
{ {
ret = (ret << 8) | b; ret = (ret * 31) + b;
} }
return ret; return ret;
} }