Package org.eclipse.net4j.util.ref
Class Interner<E>
java.lang.Object
org.eclipse.net4j.util.ref.Interner<E>
- Since:
- 3.3
- Author:
- Ed Merks
-
Nested Class Summary
Modifier and TypeClassDescriptionprotected static class
A weak reference holder that caches the hash code of the referent and is chained in theentries
to handle collisions. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
addEntry
(Interner.Entry<E> entry) Adds a new entry,ensures
the capacity is sufficient and increases thesize
.protected Interner.Entry<E>
createEntry
(E object, int hashCode) protected boolean
Returns true if the two objects are to be considered equal.protected Interner.Entry<E>
getEntry
(int hashCode) Gets the first entry in the table with exactly the given hash code.void
grow
(int minimumCapacity) Ensures that the set has at least the specifies capacity.protected int
-
Constructor Details
-
Interner
public Interner() -
Interner
public Interner(int minimumCapacity)
-
-
Method Details
-
grow
public void grow(int minimumCapacity) Ensures that the set has at least the specifies capacity. Higher capacity ensures fewer collisions hence faster lookup. Does nothing if the specified capacity is smaller than the current capacity. -
intern
-
getEntry
Gets the first entry in the table with exactly the given hash code. It's very useful to callInterner.Entry.getNextEntry()
to yield the next entry with exactly this same hash code. -
hashCode
-
equals
Returns true if the two objects are to be considered equal. The first object will always be the one passed in as an argument tointern(Object)
. -
createEntry
-
addEntry
Adds a new entry,ensures
the capacity is sufficient and increases thesize
.
-