Package org.eclipse.rdf4j.sail.memory
Class MemoryStore
- java.lang.Object
- 
- org.eclipse.rdf4j.sail.helpers.AbstractSail
- 
- org.eclipse.rdf4j.sail.helpers.AbstractNotifyingSail
- 
- org.eclipse.rdf4j.sail.memory.MemoryStore
 
 
 
- 
- All Implemented Interfaces:
- FederatedServiceResolverClient,- NotifyingSail,- Sail
 
 public class MemoryStore extends AbstractNotifyingSail implements FederatedServiceResolverClient An implementation of the Sail interface that stores its data in main memory and that can use a file for persistent storage. This Sail implementation supports single, isolated transactions. This means that changes to the data are not visible until a transaction is committed and that concurrent transactions are not possible. When another transaction is active, calls to startTransaction() will block until the active transaction is committed or rolled back. The MemoryStore is designed for datasets with fewer than 100,000 triples. The MemoryStore uses hash tables, and when these hash tables fill up it copies the values to larger hash tables. This can cause strain on the garbage collector due to lots of memory being allocated and freed.- Author:
- Arjohn Kampman, jeen
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected static StringDATA_FILE_NAMEprotected static StringSYNC_FILE_NAME- 
Fields inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailconnectionTimeOut, DEFAULT_CONNECTION_TIMEOUT, DEFAULT_ITERATION_SYNC_THRESHOLD, initializationLock
 
- 
 - 
Constructor SummaryConstructors Constructor Description MemoryStore()Creates a new MemoryStore.MemoryStore(File dataDir)Creates a new persistent MemoryStore.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidcancelSyncTask()protected voidcancelSyncTimer()protected NotifyingSailConnectiongetConnectionInternal()Returns a store-specific SailConnection object.EvaluationStrategyFactorygetEvaluationStrategyFactory()FederatedServiceResolvergetFederatedServiceResolver()booleangetPersist()longgetSyncDelay()Gets the currently configured sync delay.ValueFactorygetValueFactory()Gets a ValueFactory object that can be used to create IRI-, blank node-, literal- and statement objects.protected voidinitializeInternal()Initializes this repository.booleanisWritable()Checks whether this Sail object is writable.voidnotifySailChanged(SailChangedEvent event)Notifies all registered SailChangedListener's of changes to the contents of this Sail.protected voidscheduleSyncTask()voidsetEvaluationStrategyFactory(EvaluationStrategyFactory factory)Sets theEvaluationStrategyto use.voidsetFederatedServiceResolver(FederatedServiceResolver resolver)Overrides theFederatedServiceResolverused by this instance, but the given resolver is not shutDown when this instance is.voidsetPersist(boolean persist)voidsetSyncDelay(long syncDelay)Sets the time (in milliseconds) to wait after a transaction was commited before writing the changed data to file.protected voidshutDownInternal()Do store-specific operations to ensure proper shutdown of the store.voidsync()Synchronizes the contents of this repository with the data that is stored on disk.- 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractNotifyingSailaddSailChangedListener, getConnection, removeSailChangedListener
 - 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailaddSupportedIsolationLevel, connectionClosed, debugEnabled, getDataDir, getDefaultIsolationLevel, getIterationCacheSyncThreshold, getSupportedIsolationLevels, init, isInitialized, isTrackResultSize, removeSupportedIsolationLevel, setConnectionTimeOut, setDataDir, setDefaultIsolationLevel, setIterationCacheSyncThreshold, setSupportedIsolationLevels, setSupportedIsolationLevels, setTrackResultSize, shutDown, toString
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.sail.SailgetDataDir, getDefaultIsolationLevel, getSupportedIsolationLevels, init, setDataDir, shutDown
 
- 
 
- 
- 
- 
Field Detail- 
DATA_FILE_NAMEprotected static final String DATA_FILE_NAME - See Also:
- Constant Field Values
 
 - 
SYNC_FILE_NAMEprotected static final String SYNC_FILE_NAME - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
MemoryStorepublic MemoryStore() Creates a new MemoryStore.
 - 
MemoryStorepublic MemoryStore(File dataDir) Creates a new persistent MemoryStore. If the specified data directory contains an existing store, its contents will be restored upon initialization.- Parameters:
- dataDir- the data directory to be used for persistence.
 
 
- 
 - 
Method Detail- 
setPersistpublic void setPersist(boolean persist) 
 - 
getPersistpublic boolean getPersist() 
 - 
setSyncDelaypublic void setSyncDelay(long syncDelay) Sets the time (in milliseconds) to wait after a transaction was commited before writing the changed data to file. Setting this variable to 0 will force a file sync immediately after each commit. A negative value will deactivate file synchronization until the Sail is shut down. A positive value will postpone the synchronization for at least that amount of milliseconds. If in the meantime a new transaction is started, the file synchronization will be rescheduled to wait for another syncDelay ms. This way, bursts of transaction events can be combined in one file sync.The default value for this parameter is 0 (immediate synchronization). - Parameters:
- syncDelay- The sync delay in milliseconds.
 
 - 
getSyncDelaypublic long getSyncDelay() Gets the currently configured sync delay.- Returns:
- syncDelay The sync delay in milliseconds.
- See Also:
- setSyncDelay(long)
 
 - 
getEvaluationStrategyFactorypublic EvaluationStrategyFactory getEvaluationStrategyFactory() - Returns:
- Returns the EvaluationStrategy.
 
 - 
setEvaluationStrategyFactorypublic void setEvaluationStrategyFactory(EvaluationStrategyFactory factory) Sets theEvaluationStrategyto use.
 - 
getFederatedServiceResolverpublic FederatedServiceResolver getFederatedServiceResolver() - Returns:
- Returns the SERVICE resolver.
 
 - 
setFederatedServiceResolverpublic void setFederatedServiceResolver(FederatedServiceResolver resolver) Overrides theFederatedServiceResolverused by this instance, but the given resolver is not shutDown when this instance is.- Specified by:
- setFederatedServiceResolverin interface- FederatedServiceResolverClient
- Parameters:
- resolver- The SERVICE resolver to set.
 
 - 
initializeInternalprotected void initializeInternal() throws SailExceptionInitializes this repository. If a persistence file is defined for the store, the contents will be restored.- Overrides:
- initializeInternalin class- AbstractSail
- Throws:
- SailException- when initialization of the store failed.
 
 - 
shutDownInternalprotected void shutDownInternal() throws SailExceptionDescription copied from class:AbstractSailDo store-specific operations to ensure proper shutdown of the store.- Specified by:
- shutDownInternalin class- AbstractSail
- Throws:
- SailException
 
 - 
isWritablepublic boolean isWritable() Checks whether this Sail object is writable. A MemoryStore is not writable if a read-only data file is used.- Specified by:
- isWritablein interface- Sail
 
 - 
getConnectionInternalprotected NotifyingSailConnection getConnectionInternal() throws SailException Description copied from class:AbstractSailReturns a store-specific SailConnection object.- Specified by:
- getConnectionInternalin class- AbstractNotifyingSail
- Returns:
- A connection to the store.
- Throws:
- SailException
 
 - 
getValueFactorypublic ValueFactory getValueFactory() Description copied from interface:SailGets a ValueFactory object that can be used to create IRI-, blank node-, literal- and statement objects.- Specified by:
- getValueFactoryin interface- Sail
- Returns:
- a ValueFactory object for this Sail object.
 
 - 
notifySailChangedpublic void notifySailChanged(SailChangedEvent event) Description copied from class:AbstractNotifyingSailNotifies all registered SailChangedListener's of changes to the contents of this Sail.- Overrides:
- notifySailChangedin class- AbstractNotifyingSail
 
 - 
scheduleSyncTaskprotected void scheduleSyncTask() throws SailException- Throws:
- SailException
 
 - 
cancelSyncTaskprotected void cancelSyncTask() 
 - 
cancelSyncTimerprotected void cancelSyncTimer() 
 - 
syncpublic void sync() throws SailExceptionSynchronizes the contents of this repository with the data that is stored on disk. Data will only be written when the contents of the repository and data in the file are out of sync.- Throws:
- SailException
 
 
- 
 
-