| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectorg.helidb.backend.AbstractDatabaseBackend<K,V,Long>
org.helidb.backend.heap.HeapBackend<K,V>
K - The type of keys.V - The type of values.public class HeapBackend<K,V>
This backend implementation takes database records and puts them on a heap.
 The heap is a file where new records are appended, so inserts are very fast.
 To find a record, the entire heap is scanned from the beginning, which means
 that the average time to find a database record increases linearly with the
 number of records in the database (minus the effects of hard drive caching).
 If a record is deleted, the heap becomes fragmented and. It can then be
 defragmented by calling the compact() method.
 
 Keys and values may be of variable size. If both keys and values are of
 constant size when serialized, use
 ConstantRecordSizeHeapBackend instead.
 
 The maximum length of a database record (key and value) is Integer.MAX_VALUE - 4 bytes.
 
 The format of the file where the data is stored is:
 
 
The total size of a record is theFile ::= Record*Record ::= Record_header Key ValueRecord_header ::=Deleted_flag&ndash 1 byte: 1 for deleted, 0 for activeRecord_size&ndash 4 bytes, big-endian integer, size of key + valueKey_size&ndash 4 bytes, big-endian integer, size of key
Record_size plus the size of the
 header (nine bytes).
 
 The backend uses a key and a value
 Serializer for serializing and
 interpreting keys and values. It is required that different keys never are
 serialized to the same byte array value and vice versa.
 
 When iterating over a database using this backend using a
 Cursor, an iterator, a key iterator or a value iterator,
 the records are always returned in the order that they were inserted. If the
 database uses an index, the index implementation may modify that behavior.
 (See the documentation for the index implementation.)
 
 Backwards iteration is not supported by this backend. The
 getLastPosition() and getPreviousPosition(Long) methods
 both throw UnsupportedOperationException:s. Adding an index to the
 database backend may change that.
 
 This backend supports all search modes defined in SearchMode.
 Searching the database using SearchMode.CLOSEST_MATCH,
 SearchMode.CLOSEST_ABOVE or SearchMode.CLOSEST_BELOW and no
 custom Comparator requires that the keys in the backend are
 Comparable and it will cause the backend to iterate through all
 records to find the closest matching key (unless an exact match is found
 before the end of the data).
ConstantRecordSizeHeapBackend, 
HeapBackendFactory| Field Summary | |
|---|---|
| static int | DEFAULT_BUFFER_SIZEThe default buffer size for internal buffers. | 
| Constructor Summary | |
|---|---|
| HeapBackend(RandomlyAccessibleFile dbFile,
            boolean readOnly,
            Serializer<K> keySerializer,
            Serializer<V> valueSerializer,
            LogAdapterHolder lah)Create a new heap backend for read/write access with database data starting at position 0in the supplied file and the buffer size
 set to 8192 bytes. | |
| HeapBackend(RandomlyAccessibleFile dbFile,
            boolean readOnly,
            Serializer<K> keySerializer,
            Serializer<V> valueSerializer,
            long startPosOfDb,
            int bufferSize,
            LogAdapterHolder lah)Create a new heap backend. | |
| Method Summary | |
|---|---|
| protected  void | assertNotClosed()Subclasses implement this to throw an IllegalStateExceptionif
 the database backend is closed. | 
|  void | clear()Wipe out the entire database. | 
|  void | close()Close this database backend and release all resources associated with it (close files and release locks, for instance). | 
|  boolean | compact()This compacts the database by removing holes left by deleted elements. | 
|  boolean | delete(K key)Delete the record with the supplied key, if it exists. | 
|  Long | find(K key)Find the position of the record with the supplied key in the database backend. | 
|  void | forEachKey(ForEachKeyCallback<K,Long> callback)For each key in the database, call the callback object. | 
|  Long | getFirstPosition()Get the position of the "first" record in the backend. | 
|  Set<K> | getKeys()Return an immutable Setcontaining all keys in the database. | 
|  Long | getLastPosition()This method throws an UnsupportedOperationException. | 
|  Long | getNextPosition(Long pos)Get the position of the "next" record in the backend, relative to the record at the supplied position. | 
|  Long | getPreviousPosition(Long pos)This method throws an UnsupportedOperationException. | 
|  Set<Record<K,V>> | getRecords()Return an immutable Setcontaining all database records (keys and
 values). | 
|  V | getValueFor(K key)Get the value for the record with the supplied key. | 
|  Collection<V> | getValues()Return an immutable Collectioncontaining all values in the
 database. | 
|  Long | insert(K key,
       V value)Insert a new record in the database. | 
|  Long | insertCheckKeyUnique(K key,
                     V value)Insert a new record in the database after verifying that the key is unique within the database. | 
|  boolean | insertOrUpdate(K key,
               V value)If a record with the supplied key exists, update its value. | 
|  Iterator<Record<K,V>> | iterator() | 
|  Iterator<K> | keyIterator()Get an iterator for all keys in the database. | 
|  K | readKeyAt(Long pos)Read the key at the supplied position. | 
|  Record<K,V> | readRecordAt(Long pos)Read the record (key and value) at the specified position. | 
|  V | readValueAt(Long pos)Read the value at the specified position. | 
|  V | remove(K key)Delete the record with the supplied key and return its value. | 
|  void | removeAt(Long pos,
         K key)Delete the record at the supplied position. | 
|  void | replaceContentsWith(RandomAccess ra,
                    long dataSize)Replace the contents of the database with content read from the supplied RandomAccess. | 
|  Pair<Long> | update(K key,
       V value)Update an existing record with a new value. | 
|  Long | updateAt(Long pos,
         K key,
         V value)Update the record at the supplied position with the new value. | 
|  Iterator<V> | valueIterator()Get an iterator for all the values in the database. | 
|  long | writeContentsTo(RandomAccess ra)Write the contents of the entire database to the current position in the supplied RandomAccess. | 
| Methods inherited from class org.helidb.backend.AbstractDatabaseBackend | 
|---|
| addRecordMoveListener, find, find, getContentsVersion, hasRecordMoveListeners, notifyRecordMoveListeners, removeRecordMoveListener, updateContentsVersion | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
public static final int DEFAULT_BUFFER_SIZE
| Constructor Detail | 
|---|
public HeapBackend(RandomlyAccessibleFile dbFile,
                   boolean readOnly,
                   Serializer<K> keySerializer,
                   Serializer<V> valueSerializer,
                   LogAdapterHolder lah)
0 in the supplied file and the buffer size
 set to 8192 bytes. The buffer size is used when
 creating internal temporary buffers used when compacting the database,
 etc.
 
 The HeapBackendBuilder may be more convenient to use than this
 constructor.
dbFile - The file containing the database data.readOnly - Should the database only be read from?keySerializer - Serializer for keys.valueSerializer - Serializer for values.lah - A log adapter holder.HeapBackend(RandomlyAccessibleFile, boolean, Serializer,
 Serializer, long, int, LogAdapterHolder)
public HeapBackend(RandomlyAccessibleFile dbFile,
                   boolean readOnly,
                   Serializer<K> keySerializer,
                   Serializer<V> valueSerializer,
                   long startPosOfDb,
                   int bufferSize,
                   LogAdapterHolder lah)
            throws IllegalArgumentException
 The HeapBackendBuilder may be more convenient to use than this
 constructor.
dbFile - The file containing the database data.readOnly - Should the database be read only?keySerializer - Serializer for keys.valueSerializer - Serializer for values.startPosOfDb - The start position of the database in the database
 file. The database file may contain a header that this backend does not
 care about. In this case, set this value to the size of that header.bufferSize - The size of internal buffers used when compacting the
 database. 8192 may be appropriate. If the
 database has large records, a higher value speeds up compact() a
 bit at the expense of more memory usage.lah - A log adapter holder.
IllegalArgumentException - If the buffer size is negative.HeapBackend(RandomlyAccessibleFile, boolean, Serializer,
 Serializer, LogAdapterHolder)| Method Detail | 
|---|
protected void assertNotClosed()
                        throws IllegalStateException
AbstractDatabaseBackendIllegalStateException if
 the database backend is closed.
assertNotClosed in class AbstractDatabaseBackend<K,V,Long>IllegalStateException - Thrown if the database backend is closed.
public Long insert(K key,
                   V value)
DatabaseBackend
key - The key. It is not verified that this key is unique. Inserting
 duplicate keys will result in unspecified behavior from the backend.value - The value.
public Long insertCheckKeyUnique(K key,
                                 V value)
DatabaseBackend
key - The key.value - The value.
public boolean insertOrUpdate(K key,
                              V value)
DatabaseBackend
key - The key.value - The value.
true if an existing record was updated, false if
 a new record was inserted.
public Long updateAt(Long pos,
                     K key,
                     V value)
DatabaseBackendIt is up to the implementation to decide exactly how this is done. It is not required that the record should be located at the same position in the backend after the update. One strategy for implementing this method is to delete the old record and insert a new record with the updated values.
pos - The position of the record to update.key - The record's key. The key is not modified by the update.value - The new value.
public Pair<Long> update(K key,
                         V value)
DatabaseBackendIt is up to the implementation to decide exactly how this is done. It is not required that the record should be located at the same position in the backend after the update. One strategy for implementing this method is to delete the old record and insert a new record with the updated values.
key - The record's key.value - The record's new value.
public Long getFirstPosition()
                      throws WrappedIOException,
                             IllegalStateException
DatabaseBackend
null
 if the backend is empty.
WrappedIOException - On I/O errors.
IllegalStateException - If the database backend has been closed.DatabaseBackend.getLastPosition(), 
DatabaseBackend.getNextPosition(Object), 
DatabaseBackend.getPreviousPosition(Object)
public Long getLastPosition()
                     throws IllegalStateException,
                            UnsupportedOperationException
UnsupportedOperationException.
null
 if the backend is empty.
UnsupportedOperationException - Backwards iteration is not
 supported by the heap backend.
IllegalStateException - If the database backend has been closed.DatabaseBackend.getFirstPosition(), 
DatabaseBackend.getNextPosition(Object), 
DatabaseBackend.getPreviousPosition(Object)
public Long getNextPosition(Long pos)
                     throws WrappedIOException,
                            IllegalStateException
DatabaseBackend
pos - The position to search from. This must be the position of a
 record in the backend. If it is not, the behavior of this method is
 unspecified.
null if the supplied position references the last record in the backend
 (the position returned from DatabaseBackend.getLastPosition()).
WrappedIOException - On I/O errors.
IllegalStateException - If the database backend has been closed.DatabaseBackend.getFirstPosition(), 
DatabaseBackend.getLastPosition(), 
DatabaseBackend.getPreviousPosition(Object)
public Long getPreviousPosition(Long pos)
                         throws WrappedIOException,
                                IllegalStateException,
                                UnsupportedOperationException
UnsupportedOperationException.
pos - The position to search from. This must be the position of a
 record in the backend. If it is not, the behavior of this method is
 unspecified.
null if the supplied position references the first record in the
 backend (the position returned from DatabaseBackend.getFirstPosition()).
UnsupportedOperationException - Backwards iteration is not
 supported by the heap backend.
WrappedIOException - On I/O errors.
IllegalStateException - If the database backend has been closed.DatabaseBackend.getFirstPosition(), 
DatabaseBackend.getLastPosition(), 
DatabaseBackend.getNextPosition(Object)public Iterator<Record<K,V>> iterator()
public Iterator<K> keyIterator()
DatabaseBackend
 If the database is modified after calling this method, the methods of the
 Iterator returned will throw
 ConcurrentModificationException
Iterator over the database's keys.public Iterator<V> valueIterator()
DatabaseBackend
 If the database is modified after calling this method, the methods of the
 Iterator returned will throw
 ConcurrentModificationException
Iterator over the database's values.public void clear()
DatabaseBackend
public Long find(K key)
DatabaseBackend
key - The key to find.
null if not found.DatabaseBackend.find(Comparable, SearchMode), 
DatabaseBackend.find(Object, SearchMode, Comparator)public V getValueFor(K key)
DatabaseBackend
key - The record's key.
null if no record in the database
 has the supplied key.public Set<K> getKeys()
DatabaseBackendSet containing all keys in the database.
Set containing all keys in the database. If
 the database is empty, this method returns an empty Set.public Collection<V> getValues()
DatabaseBackendCollection containing all values in the
 database.
Collection containing all values in the
 database. If the database is empty, this method returns an empty Collection.public Set<Record<K,V>> getRecords()
DatabaseBackendSet containing all database records (keys and
 values).
Set containing all database records. If the
 database is empty, this method returns an empty Set.
public K readKeyAt(Long pos)
            throws WrappedIOException,
                   IllegalStateException
DatabaseBackend
pos - The position of the record containing the key. This must be a
 valid position in the backend. It it is not, the behavior of this method
 is unspecified.
WrappedIOException - On I/O errors.
IllegalStateException - If the database backend has been closed.DatabaseBackend.readValueAt(Object), 
DatabaseBackend.readRecordAt(Object)public V readValueAt(Long pos)
DatabaseBackend
pos - The position of the record containing the value. This must be
 a valid position in the backend. If it is not, the behavior of this
 method is unspecified.
DatabaseBackend.readKeyAt(Object), 
DatabaseBackend.readRecordAt(Object)
public Record<K,V> readRecordAt(Long pos)
                         throws WrappedIOException,
                                IllegalStateException
DatabaseBackend
pos - The position of the record. This must be a valid position in
 the backend. If it is not, the behavior of this method is unspecified.
WrappedIOException - On I/O errors.
IllegalStateException - If the database backend has been closed.DatabaseBackend.readKeyAt(Object), 
DatabaseBackend.readValueAt(Object)
public void removeAt(Long pos,
                     K key)
DatabaseBackend
pos - The position of the record to delete.key - The key for the record to remove.public boolean delete(K key)
DatabaseBackend
key - The record's key.
true if a record was deleted.public V remove(K key)
DatabaseBackend
key - The record's key.
null if no record in the database
 has the supplied key.public void forEachKey(ForEachKeyCallback<K,Long> callback)
DatabaseBackendThis can for instance be used for building indices for the database.
callback - The callback object to call for each key.public boolean compact()
true if the backend was modified, false if not.public long writeContentsTo(RandomAccess ra)
DatabaseBackendRandomAccess.
 
 After writing, the current position of the RandomAccess should be
 at the end of the written data.
ra - The RandomAccess to write to. It is not closed after
 writing.
public void replaceContentsWith(RandomAccess ra,
                                long dataSize)
DatabaseBackendRandomAccess. The database contents start at the RandomAccess' current position.
ra - The RandomAccess to read data from. It should not be
 closed after reading.dataSize - The total size of the database data in bytes.public void close()
DatabaseBackend
| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||