|
Apache JMeter | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.apache.jorphan.collections.HashTree
This class is used to create a tree structure of objects. Each element in the tree is also a key to the next node down in the tree. It provides many ways to add objects and branches, as well as many ways to retrieve.
HashTree implements the Map interface for convenience reasons. The main difference between a Map and a HashTree is that the HashTree organizes the data into a recursive tree structure, and provides the means to manipulate that structure.
Of special interest is the traverse(HashTreeTraverser)
method, which
provides an expedient way to traverse any HashTree by implementing the
HashTreeTraverser
interface in order to perform some operation on the
tree, or to extract information from the tree.
HashTreeTraverser
,
SearchByClass
,
Serialized FormNested Class Summary |
Nested classes inherited from class java.util.Map |
Map.Entry |
Field Summary | |
protected Map |
data
|
Constructor Summary | |
|
HashTree()
Creates an empty new HashTree. |
|
HashTree(Collection keys)
Creates a new HashTree and adds all the objects in the given collection as top-level nodes in the tree. |
protected |
HashTree(Map _map)
Allow subclasses to provide their own Map. |
|
HashTree(Object key)
Creates a new HashTree and adds the given object as a top-level node. |
|
HashTree(Object[] keys)
Creates a new HashTree and adds all the objects in the given array as top-level nodes in the tree. |
Method Summary | |
void |
add(Collection keys)
Adds a bunch of keys into the HashTree at the current level. |
void |
add(Collection treePath,
Collection values)
Adds a series of nodes into the HashTree using the given path. |
HashTree |
add(Collection treePath,
Object value)
Adds a series of nodes into the HashTree using the given path. |
void |
add(Collection treePath,
Object[] values)
Adds a series of nodes into the HashTree using the given path. |
void |
add(HashTree newTree)
Adds all the nodes and branches of the given tree to this tree. |
HashTree |
add(Object key)
Adds an key into the HashTree at the current level. |
void |
add(Object[] keys)
Adds all the given objects as nodes at the current level. |
void |
add(Object[] treePath,
Collection values)
Adds a series of nodes into the HashTree using the given path. |
HashTree |
add(Object[] treePath,
Object value)
|
void |
add(Object[] treePath,
Object[] values)
Adds a series of nodes into the HashTree using the given path. |
void |
add(Object key,
Collection values)
Adds a key as a node at the current level and then adds all the objects in the second argument as nodes of the new node. |
void |
add(Object key,
HashTree subTree)
Adds a key as a node at the current level and then adds the given HashTree to that new node. |
HashTree |
add(Object key,
Object value)
Adds a key and it's value in the HashTree. |
void |
add(Object key,
Object[] values)
Adds a key and it's values in the HashTree. |
protected HashTree |
addTreePath(Collection treePath)
|
void |
clear()
Clears the HashTree of all contents. |
Object |
clone()
Create a clone of this HashTree. |
protected void |
cloneTree(HashTree newTree)
|
boolean |
containsKey(Object o)
If the HashTree contains the given object as a key at the top level, then a true result is returned, otherwise false. |
boolean |
containsValue(Object value)
Implemented as required by the Map interface, but is not very useful here. |
protected HashTree |
createNewTree()
Creates a new tree. |
protected HashTree |
createNewTree(Collection values)
Creates a new tree. |
protected HashTree |
createNewTree(Object key)
Creates a new tree. |
Set |
entrySet()
Exists to satisfy the Map interface. |
boolean |
equals(Object o)
Compares all objects in the tree and verifies that the two trees contain the same objects at the same tree levels. |
Object |
get(Object key)
Returns the HashTree object associated with the given key. |
Object[] |
getArray()
Gets an array of all keys in the current HashTree node. |
Object[] |
getArray(Collection treePath)
Recurses down into the HashTree stucture using each subsequent key in the treePath argument, and returns an array of keys of the HashTree object at the end of the recursion. |
Object[] |
getArray(Object key)
Gets an array of all keys in the HashTree mapped to the given key of the current HashTree object (in other words, one level down). |
Object[] |
getArray(Object[] treePath)
Recurses down into the HashTree stucture using each subsequent key in the array of keys, and returns an array of keys of the HashTree object at the end of the recursion. |
HashTree |
getTree(Collection treePath)
Gets the HashTree object mapped to the last key in the SortedSet by recursing through the HashTree structure one key at a time. |
HashTree |
getTree(Object key)
Gets the HashTree mapped to the given key. |
HashTree |
getTree(Object[] treePath)
Gets the HashTree object mapped to the last key in the array by recursing through the HashTree structure one key at a time. |
protected HashTree |
getTreePath(Collection treePath)
|
int |
hashCode()
Returns a hashcode for this HashTree. |
boolean |
isEmpty()
If the HashTree is empty, true is returned, false otherwise. |
Set |
keySet()
Returns a Set of all the keys in the top-level of this HashTree. |
Collection |
list()
Gets a Collection of all keys in the current HashTree node. |
Collection |
list(Collection treePath)
Recurses down into the HashTree stucture using each subsequent key in the List of keys, and returns the Set of keys of the HashTree object at the end of the recursion. |
Collection |
list(Object key)
Gets a Set of all keys in the HashTree mapped to the given key of the current HashTree object (in other words, one level down. |
Collection |
list(Object[] treePath)
Recurses down into the HashTree stucture using each subsequent key in the array of keys, and returns the Set of keys of the HashTree object at the end of the recursion. |
Object |
put(Object key,
Object value)
This is the same as calling HashTree.add(key,value). |
void |
putAll(Map map)
The Map given must also be a HashTree, otherwise an UnsupportedOperationException is thrown. |
Object |
remove(Object key)
Removes the entire branch specified by the given key. |
void |
replace(Object currentKey,
Object newKey)
Finds the given current key, and replaces it with the given new key. |
HashTree |
search(Object key)
Searches the HashTree structure for the given key. |
void |
set(Collection values)
Sets the nodes of the current tree to be the objects of the given collection. |
void |
set(Collection treePath,
Collection values)
Sets a series of keys into the HashTree. |
void |
set(Collection treePath,
Object[] values)
Sets a series of keys into the HashTree. |
void |
set(Object[] treePath,
Collection values)
Sets a series of keys into the HashTree. |
void |
set(Object[] treePath,
Object[] values)
Sets a series of keys into the HashTree. |
void |
set(Object key,
Collection values)
Sets a key and its values in the HashTree. |
void |
set(Object key,
HashTree t)
Sets a key into the current tree and assigns it a HashTree as its subtree. |
void |
set(Object key,
Object value)
Sets a key and it's value in the HashTree. |
void |
set(Object key,
Object[] values)
Sets a key and its values in the HashTree. |
int |
size()
Returns the number of top-level entries in the HashTree. |
String |
toString()
Generate a printable representation of the tree. |
void |
traverse(HashTreeTraverser visitor)
Allows any implementation of the HashTreeTraverser interface to easily traverse (depth-first) all the nodes of the HashTree. |
Collection |
values()
Returns a collection of all the sub-trees of the current tree. |
Methods inherited from class java.lang.Object |
finalize, getClass, notify, notifyAll, wait, wait, wait |
Field Detail |
protected final Map data
Constructor Detail |
public HashTree()
protected HashTree(Map _map)
public HashTree(Object key)
key
- public HashTree(Collection keys)
keys
- a collection of objects to be added to the created HashTree.public HashTree(Object[] keys)
Method Detail |
public void putAll(Map map)
putAll
in interface Map
add(HashTree)
,
Map.putAll(Map)
public Set entrySet()
entrySet
in interface Map
Map.entrySet()
public boolean containsValue(Object value)
containsValue
in interface Map
value
- Object to be tested as a value.
Map.containsValue(Object)
public Object put(Object key, Object value)
put
in interface Map
key
- to usevalue
- to store against keyMap.put(Object, Object)
public void clear()
clear
in interface Map
Map.clear()
public Collection values()
values
in interface Map
Map.values()
public void add(Object key, HashTree subTree)
key
- key to create in this treesubTree
- sub tree to add to the node created for the first argument.public void add(HashTree newTree)
newTree
- public boolean containsKey(Object o)
containsKey
in interface Map
o
- Object to be tested as a key.
Map.containsKey(Object)
public boolean isEmpty()
isEmpty
in interface Map
public void set(Object key, Object value)
key
- key to be set upvalue
- value to be set up as a key in the secondary nodepublic void set(Object key, HashTree t)
key
- key to be set upt
- HashTree that the key maps topublic void set(Object key, Object[] values)
key
- Key to be set upvalues
- Array of objects to be added as keys in the secondary nodepublic void set(Object key, Collection values)
key
- key to be set upvalues
- Collection of objects to be added as keys in the secondary
nodepublic void set(Object[] treePath, Object[] values)
treePath
- array of keys to put into HashTreevalues
- array of values to be added as keys to bottom-most nodepublic void set(Object[] treePath, Collection values)
treePath
- array of keys to put into HashTreevalues
- Collection of values to be added as keys to bottom-most nodepublic void set(Collection treePath, Object[] values)
treePath
- collection of keys to put into HashTreevalues
- array of values to be added as keys to bottom-most nodepublic void set(Collection values)
values
- Collection of objects to set as nodes.public void set(Collection treePath, Collection values)
treePath
- list of keys to put into HashTreevalues
- collection of values to be added as keys to bottom-most nodepublic HashTree add(Object key)
key
- key to be added to HashTreepublic void add(Object[] keys)
keys
- Array of Keys to be added to HashTree.public void add(Collection keys)
keys
- Collection of Keys to be added to HashTree.public HashTree add(Object key, Object value)
key
- key to be addedvalue
- value to be added as a key in the secondary nodepublic void add(Object key, Object[] values)
key
- key to be addedvalues
- array of objects to be added as keys in the secondary nodepublic void add(Object key, Collection values)
key
- key to be addedvalues
- Collection of objects to be added as keys in the secondary
nodepublic void add(Object[] treePath, Object[] values)
treePath
- an array of objects representing a pathvalues
- array of values to be added as keys to bottom-most nodepublic void add(Object[] treePath, Collection values)
treePath
- an array of objects representing a pathvalues
- collection of values to be added as keys to bottom-most nodepublic HashTree add(Object[] treePath, Object value)
public void add(Collection treePath, Object[] values)
treePath
- a list of objects representing a pathvalues
- array of values to be added as keys to bottom-most nodepublic HashTree add(Collection treePath, Object value)
treePath
- a list of objects representing a pathvalue
- Object to add as a node to bottom-most nodepublic void add(Collection treePath, Collection values)
treePath
- a SortedSet of objects representing a pathvalues
- Collection of values to be added as keys to bottom-most nodeprotected HashTree addTreePath(Collection treePath)
public HashTree getTree(Object key)
key
- Key used to find appropriate HashTree()public Object get(Object key)
getTree(Object)
.
get
in interface Map
Map.get(Object)
public HashTree getTree(Object[] treePath)
treePath
- array of keys.
public Object clone()
protected void cloneTree(HashTree newTree)
protected HashTree createNewTree()
protected HashTree createNewTree(Object key)
protected HashTree createNewTree(Collection values)
public HashTree getTree(Collection treePath)
treePath
- Collection of keys
public Collection list()
public Collection list(Object key)
key
- key used to find HashTree to get list of
public Object remove(Object key)
remove
in interface Map
Map.remove(Object)
public Collection list(Object[] treePath)
treePath
- Array of keys used to recurse into HashTree structure
public Collection list(Collection treePath)
treePath
- List of keys used to recurse into HashTree structure
public void replace(Object currentKey, Object newKey)
public Object[] getArray()
public Object[] getArray(Object key)
key
- key used to find HashTree to get list of
public Object[] getArray(Object[] treePath)
treePath
- array of keys used to recurse into HashTree structure
public Object[] getArray(Collection treePath)
treePath
- list of keys used to recurse into HashTree structure
protected HashTree getTreePath(Collection treePath)
public int hashCode()
hashCode
in interface Map
Object.hashCode()
public boolean equals(Object o)
equals
in interface Map
o
- Object to be compared againstObject.equals(Object)
public Set keySet()
keySet
in interface Map
Map.keySet()
public HashTree search(Object key)
key
- Key to search for
null
public int size()
size
in interface Map
Map.size()
public void traverse(HashTreeTraverser visitor)
HashTreeTraverser
public String toString()
|
Apache JMeter | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |