@Beta public interface Hasher extends 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.
The result of calling any methods after calling hash()
is undefined.
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().putString("ab").putString("c").hash()
newHasher().putString("a").putString("bc").hash()
newHasher().putChar('a').putChar('b').putChar('c').hash()
If you wish to avoid this, you should either prepend or append the size of each chunk.
For example:
newHasher().putInt(s1.length()).putString(s1).putInt(s2.length()).putString(s2).hash()
Modifier and Type | Method and Description |
---|---|
HashCode |
hash()
Computes a hash code based on the data that have been provided to this hasher.
|
Hasher |
putBoolean(boolean b)
Equivalent to
putByte(b ? (byte) 1 : (byte) 0) . |
Hasher |
putByte(byte b)
Puts a byte into this sink.
|
Hasher |
putBytes(byte[] bytes)
Puts an array of bytes into this sink.
|
Hasher |
putBytes(byte[] bytes,
int off,
int len)
Puts a chunk of an array of bytes into this sink.
|
Hasher |
putChar(char c)
Puts a character into this sink.
|
Hasher |
putDouble(double d)
Equivalent to
putLong(Double.doubleToRawLongBits(d)) . |
Hasher |
putFloat(float f)
Equivalent to
putInt(Float.floatToRawIntBits(f)) . |
Hasher |
putInt(int i)
Puts an int into this sink.
|
Hasher |
putLong(long l)
Puts a long into this sink.
|
<T> Hasher |
putObject(T instance,
Funnel<? super T> funnel)
A simple convenience for
funnel.funnel(object, this) . |
Hasher |
putShort(short s)
Puts a short into this sink.
|
Hasher |
putString(CharSequence charSequence)
Equivalent to processing each
char value in the CharSequence , in order. |
Hasher |
putString(CharSequence charSequence,
Charset charset)
Equivalent to
putBytes(charSequence.toString().getBytes(charset)) . |
Hasher putByte(byte b)
PrimitiveSink
putByte
in interface PrimitiveSink
b
- a byteHasher putBytes(byte[] bytes)
PrimitiveSink
putBytes
in interface PrimitiveSink
bytes
- a byte arrayHasher putBytes(byte[] bytes, int off, int len)
PrimitiveSink
bytes[off]
is the first byte written,
bytes[off + len - 1]
is the last.putBytes
in interface PrimitiveSink
bytes
- a byte arrayoff
- the start offset in the arraylen
- the number of bytes to writeHasher putShort(short s)
PrimitiveSink
putShort
in interface PrimitiveSink
Hasher putInt(int i)
PrimitiveSink
putInt
in interface PrimitiveSink
Hasher putLong(long l)
PrimitiveSink
putLong
in interface PrimitiveSink
Hasher putFloat(float f)
putInt(Float.floatToRawIntBits(f))
.putFloat
in interface PrimitiveSink
Hasher putDouble(double d)
putLong(Double.doubleToRawLongBits(d))
.putDouble
in interface PrimitiveSink
Hasher putBoolean(boolean b)
putByte(b ? (byte) 1 : (byte) 0)
.putBoolean
in interface PrimitiveSink
Hasher putChar(char c)
PrimitiveSink
putChar
in interface PrimitiveSink
Hasher putString(CharSequence charSequence)
char
value in the CharSequence
, in order.
The input must not be updated while this method is in progress.putString
in interface PrimitiveSink
Hasher putString(CharSequence charSequence, Charset charset)
putBytes(charSequence.toString().getBytes(charset))
.putString
in interface PrimitiveSink
<T> Hasher putObject(T instance, Funnel<? super T> funnel)
funnel.funnel(object, this)
.Copyright © 2010-2013. All Rights Reserved.