|
" 2013 FRC Java API " |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectcom.sun.squawk.util.SquawkHashtable
public class SquawkHashtable
This class implements a variation of Hashtable
that is unsynchronized. Any
non-null
object can be used as a key or as a value.
To successfully store and retrieve objects from a hashtable, the
objects used as keys must implement the hashCode
method and the equals
method.
An instance of SquawkHashtable
has two parameters that
affect its efficiency: its capacity and its load
factor. The load factor is always 0.75. When
the number of entries in the hashtable exceeds the product of the
load factor and the current capacity, the capacity is increased by
calling the rehash
method. Larger load factors use
memory more efficiently, at the expense of larger expected time
per lookup.
If many entries are to be made into a SquawkHashtable
,
creating it with a sufficiently large capacity may allow the
entries to be inserted more efficiently than letting it perform
automatic rehashing as needed to grow the table.
This example creates a hashtable of numbers. It uses the names of the numbers as keys:
SquawkHashtable numbers = new SquawkHashtable(); numbers.put("one", new Integer(1)); numbers.put("two", new Integer(2)); numbers.put("three", new Integer(3));
To retrieve a number, use the following code:
Integer n = (Integer)numbers.get("two"); if (n != null) { System.out.println("two = " + n); }
Note: To conserve space, the CLDC implementation is based on JDK 1.1.8, not JDK 1.3.
Object.equals(java.lang.Object)
,
Object.hashCode()
,
Hashtable
,
rehash()
Nested Class Summary | |
---|---|
static interface |
SquawkHashtable.Rehasher
|
Constructor Summary | |
---|---|
SquawkHashtable()
Constructs a new, empty hashtable with a default capacity and load factor. |
|
SquawkHashtable(int initialCapacity)
Constructs a new, empty hashtable with the specified initial capacity. |
Method Summary | |
---|---|
int |
capacity()
Return the current capacity of the hashtable. |
void |
clear()
Clears this hashtable so that it contains no keys. |
boolean |
contains(Object value)
Tests if some key maps into the specified value in this hashtable. |
boolean |
containsKey(Object key)
Tests if the specified object is a key in this hashtable. |
Enumeration |
elements()
Returns an enumeration of the values in this hashtable. |
static String |
enumerationsToString(Enumeration keys,
Enumeration elements,
int size)
Utility class to get a rather long string representation of any kind of hashtable. |
Object |
get(Object key)
Returns the value to which the specified key is mapped in this hashtable. |
com.sun.squawk.util.HashtableEntry[] |
getEntryTable()
Return the internal table. |
boolean |
isEmpty()
Tests if this hashtable maps no keys to values. |
Enumeration |
keys()
Returns an enumeration of the keys in this hashtable. |
Object |
put(Object key,
Object value)
Maps the specified key to the specified
value in this hashtable. |
void |
rehash()
Rehashes the contents of the hashtable into a hashtable with a larger capacity. |
Object |
remove(Object key)
Removes the key (and its corresponding value) from this hashtable. |
SquawkHashtable |
setRehasher(SquawkHashtable.Rehasher rehasher)
|
int |
size()
Returns the number of keys in this hashtable. |
String |
toString()
Returns a rather long string representation of this hashtable. |
Methods inherited from class java.lang.Object |
---|
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public SquawkHashtable(int initialCapacity)
initialCapacity
- the initial capacity of the hashtable.
IllegalArgumentException
- if the initial capacity is less
than zeropublic SquawkHashtable()
Method Detail |
---|
public final SquawkHashtable setRehasher(SquawkHashtable.Rehasher rehasher)
public final int size()
public final boolean isEmpty()
true
if this hashtable maps no keys to values;
false
otherwise.public Enumeration keys()
Enumeration
,
JDK1.0
public Enumeration elements()
Enumeration
,
JDK1.0
public boolean contains(Object value)
containsKey
method.
value
- a value to search for.
true
if some key maps to the
value
argument in this hashtable;
false
otherwise.
NullPointerException
- if the value is null
.java.util.Hashtable#containsKeySquawkHashtableg.Object)
public boolean containsKey(Object key)
key
- possible key.
true
if the specified object is a key in this
hashtable; false
otherwise.java.util.Hashtable#SquawkHashtablejava.lang.Object)
public Object get(Object key)
key
- a key in the hashtable.
null
if the key is not mapped to any value in
this hashtable.java.util.Hashtable#SquawkHashtablelang.Object, java.lang.Object)
public void rehash()
public Object put(Object key, Object value)
key
to the specified
value
in this hashtable. Neither the key nor the
value can be null
.
The value can be retrieved by calling the get
method
with a key that is equal to the original key.
key
- the hashtable key.value
- the value.
null
if it did not have one.
NullPointerException
- if the key or value is
null
.Object.equals(java.lang.Object)
,
java.util.Hashtable#get(java.lang.ObjecSquawkHashtable JDK1.0
public Object remove(Object key)
key
- the key that needs to be removed.
null
if the key did not have a mapping.public void clear()
public String toString()
toString
in class Object
public final int capacity()
public final com.sun.squawk.util.HashtableEntry[] getEntryTable()
public static String enumerationsToString(Enumeration keys, Enumeration elements, int size)
keys
- elements
- size
-
|
" 2013 FRC Java API " |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |