Interface Hasher
- All Superinterfaces:
PrimitiveSink
PrimitiveSink that can compute a hash code after reading the input. Each hasher should
translate all multibyte values (putInt(int), putLong(long), etc) to bytes
in little-endian order.
Warning: The result of calling any methods after calling hash() is undefined.
Warning: Using a specific character encoding when hashing a CharSequence with
putString(CharSequence, Charset) is generally only useful for cross-language
compatibility (otherwise prefer putUnencodedChars(java.lang.CharSequence)). However, the character encodings
must be identical across languages. Also beware that Charset definitions may occasionally
change between Java releases.
Warning: Chunks of data that are put into the Hasher are not delimited.
The resulting HashCode is dependent only on the bytes inserted, and the order in which
they were inserted, not how those bytes were chunked into discrete put() operations. For example,
the following three expressions all generate colliding hash codes:
newHasher().putByte(b1).putByte(b2).putByte(b3).hash()
newHasher().putByte(b1).putBytes(new byte[] { b2, b3 }).hash()
newHasher().putBytes(new byte[] { b1, b2, b3 }).hash()
If you wish to avoid this, you should either prepend or append the size of each chunk. Keep in
mind that when dealing with char sequences, the encoded form of two concatenated char sequences
is not equivalent to the concatenation of their encoded form. Therefore,
putString(CharSequence, Charset) should only be used consistently with complete
sequences and not broken into chunks.
- Since:
- 11.0
-
Method Summary
Modifier and TypeMethodDescriptionhash()Deprecated.Computes a hash code based on the data that have been provided to this hasher.putBoolean(boolean b) Deprecated.Equivalent toputByte(b ? (byte) 1 : (byte) 0).putByte(byte b) Deprecated.Puts a byte into this sink.putBytes(byte[] bytes) Deprecated.Puts an array of bytes into this sink.putBytes(byte[] bytes, int off, int len) Deprecated.Puts a chunk of an array of bytes into this sink.putChar(char c) Deprecated.Puts a character into this sink.putDouble(double d) Deprecated.Equivalent toputLong(Double.doubleToRawLongBits(d)).putFloat(float f) Deprecated.Equivalent toputInt(Float.floatToRawIntBits(f)).putInt(int i) Deprecated.Puts an int into this sink.putLong(long l) Deprecated.Puts a long into this sink.<T> HasherDeprecated.A simple convenience forfunnel.funnel(object, this).putShort(short s) Deprecated.Puts a short into this sink.putString(CharSequence charSequence) Deprecated.UseputUnencodedChars(java.lang.CharSequence)instead.putString(CharSequence charSequence, Charset charset) Deprecated.Equivalent toputBytes(charSequence.toString().getBytes(charset)).putUnencodedChars(CharSequence charSequence) Deprecated.Equivalent to processing eachcharvalue in theCharSequence, in order.
-
Method Details
-
putByte
Deprecated.Description copied from interface:PrimitiveSinkPuts a byte into this sink.- Specified by:
putBytein interfacePrimitiveSink- Parameters:
b- a byte- Returns:
- this instance
-
putBytes
Deprecated.Description copied from interface:PrimitiveSinkPuts an array of bytes into this sink.- Specified by:
putBytesin interfacePrimitiveSink- Parameters:
bytes- a byte array- Returns:
- this instance
-
putBytes
Deprecated.Description copied from interface:PrimitiveSinkPuts a chunk of an array of bytes into this sink.bytes[off]is the first byte written,bytes[off + len - 1]is the last.- Specified by:
putBytesin interfacePrimitiveSink- Parameters:
bytes- a byte arrayoff- the start offset in the arraylen- the number of bytes to write- Returns:
- this instance
-
putShort
Deprecated.Description copied from interface:PrimitiveSinkPuts a short into this sink.- Specified by:
putShortin interfacePrimitiveSink
-
putInt
Deprecated.Description copied from interface:PrimitiveSinkPuts an int into this sink.- Specified by:
putIntin interfacePrimitiveSink
-
putLong
Deprecated.Description copied from interface:PrimitiveSinkPuts a long into this sink.- Specified by:
putLongin interfacePrimitiveSink
-
putFloat
Deprecated.Equivalent toputInt(Float.floatToRawIntBits(f)).- Specified by:
putFloatin interfacePrimitiveSink
-
putDouble
Deprecated.Equivalent toputLong(Double.doubleToRawLongBits(d)).- Specified by:
putDoublein interfacePrimitiveSink
-
putBoolean
Deprecated.Equivalent toputByte(b ? (byte) 1 : (byte) 0).- Specified by:
putBooleanin interfacePrimitiveSink
-
putChar
Deprecated.Description copied from interface:PrimitiveSinkPuts a character into this sink.- Specified by:
putCharin interfacePrimitiveSink
-
putUnencodedChars
Deprecated.Equivalent to processing eachcharvalue in theCharSequence, in order. The input must not be updated while this method is in progress.- Specified by:
putUnencodedCharsin interfacePrimitiveSink- Since:
- 15.0 (since 11.0 as putString(CharSequence)).
-
putString
Deprecated.UseputUnencodedChars(java.lang.CharSequence)instead. This method is scheduled for removal in Guava 16.0.Equivalent to processing eachcharvalue in theCharSequence, in order. The input must not be updated while this method is in progress.- Specified by:
putStringin interfacePrimitiveSink
-
putString
Deprecated.Equivalent toputBytes(charSequence.toString().getBytes(charset)).- Specified by:
putStringin interfacePrimitiveSink
-
putObject
Deprecated.A simple convenience forfunnel.funnel(object, this). -
hash
HashCode hash()Deprecated.Computes a hash code based on the data that have been provided to this hasher. The result is unspecified if this method is called more than once on the same instance.
-