public class CacheManager
extends java.lang.Object
Die interne Subkomponente Cache-Manager ist für das Speichern der ankommenden Daten und für die Bereitstellung bereits gespeicherte Daten zuständig. Die gespeicherten Daten werden nach ihrem Index sortiert festgehalten. Ein im Hintergrund laufender Thread, der CacheCleaner, sorgt dafür, dass die Daten, nach ihrer beim Anmelden angegebenen Verweilzeit, aus dem Cache gelöscht werden. Diese Subkomponente wird von ClientDavConnection erzeugt.
Modifier and Type | Class and Description |
---|---|
(package private) class |
CacheManager.CacheCleaner |
Modifier and Type | Field and Description |
---|---|
private DataModel |
_dataModel
Der Konfigurationsmanager
|
private static Debug |
_debug |
private java.util.Hashtable |
cache
Der Datensätzecache.
|
private CacheManager.CacheCleaner |
cleaner
Der Verwalter der Datensätze im Cache
|
private SubscriptionManager |
subscriptionManager
Der Anmeldemanager
|
Constructor and Description |
---|
CacheManager(SubscriptionManager _subscriptionManager,
ConfigurationManager _configurationManager)
Dieser Konstruktor erzeugt eine Instanz und hält eine Referenz auf die Subkomponenten Anmeldemanager und Konfigurationsmanager fest.
|
CacheManager(SubscriptionManager _subscriptionManager,
DataModel dataModel)
Dieser Konstruktor erzeugt eine Instanz und hält eine Referenz auf die Subkomponenten Anmeldemanager und Konfigurationsmanager fest.
|
Modifier and Type | Method and Description |
---|---|
(package private) void |
cleanCache(BaseSubscriptionInfo baseSubscriptionInfo)
Diese Methode wird vom SubscriptionManager aufgerufen.
|
void |
close()
Schliesst diese Komponente und beendet den Thread
CacheCleaner |
java.util.List |
getCachedData(BaseSubscriptionInfo baseSubscriptionInfo,
boolean delayedDataFlag,
int n)
Diese Methode iteriert durch den Cache-Inhalt und sammelt die letzen n Datensätze, vom aktuellen Datensatz startend in die Vergangenheit.
|
java.util.List |
getCachedData(BaseSubscriptionInfo baseSubscriptionInfo,
boolean delayedDataFlag,
long fromTime,
long toTime)
Diese Methode iteriert durch den Cache-Inhalt und sammelt die Datensätze, deren Zeitstempel zwischen den spezifizierten Zeiten liegt.
|
(package private) java.lang.Thread |
getCleaner()
Diese Methode wird für JUnit-Tests benötigt.
|
CachedObject |
getLastValueOfCachedData(BaseSubscriptionInfo baseSubscriptionInfo,
boolean delayedDataFlag)
Gibt den aktuellen Datensatz der spezifizierten Daten zurück.
|
void |
update(SendDataObject newData)
Diese Methode wird von der Protokollsteuerung DaV-DAF aufgerufen, wenn ein aktuelles Datum angekommen ist.
|
private static final Debug _debug
private SubscriptionManager subscriptionManager
Der Anmeldemanager
private final DataModel _dataModel
Der Konfigurationsmanager
private java.util.Hashtable cache
Der Datensätzecache. Als Key dient die BaseSubscriptionInfo, der Value ist eine Liste von CachedObject-Objekten.
private CacheManager.CacheCleaner cleaner
Der Verwalter der Datensätze im Cache
public CacheManager(SubscriptionManager _subscriptionManager, ConfigurationManager _configurationManager)
Dieser Konstruktor erzeugt eine Instanz und hält eine Referenz auf die Subkomponenten Anmeldemanager und Konfigurationsmanager fest. Auch eine Instanz des CacheCleaners wird gestartet.
_subscriptionManager
- Im Konstruktor wird die Methode SubscriptionManager.setCacheManager(CacheManager)
aufgerufen und dieses Objekt übergeben._configurationManager
- Wird zum anfordern des Datenmodells benötigt.CacheManager(SubscriptionManager _subscriptionManager, DataModel dataModel)
Dieser Konstruktor erzeugt eine Instanz und hält eine Referenz auf die Subkomponenten Anmeldemanager und Konfigurationsmanager fest. Auch eine Instanz des CacheCleaners wird gestartet.
_subscriptionManager
- Im Konstruktor wird die Methode SubscriptionManager.setCacheManager(CacheManager)
aufgerufen und dieses Objekt übergeben.dataModel
- Datenmodellpublic void update(SendDataObject newData) throws java.lang.InterruptedException
Diese Methode wird von der Protokollsteuerung DaV-DAF aufgerufen, wenn ein aktuelles Datum angekommen ist. Die Datensätze, die als Bytestrom ankommen, werden zuerst in Attribute umgewandelt, und ein neues CachedObject wird gebildet. Dieses wird nach dem Datensatzindex sortiert in den Cache eingefügt, und die SubscriptionManager- Subkomponente wird über das Ankommen des aktuellen Datums benachrichtigt.
newData
- Neuer Datensatzjava.lang.InterruptedException
- Wenn der Thread während eines blockierenden Aufrufs unterbrochen wurdepublic final void close()
Schliesst diese Komponente und beendet den Thread CacheCleaner
java.lang.Thread getCleaner()
Diese Methode wird für JUnit-Tests benötigt.
final void cleanCache(BaseSubscriptionInfo baseSubscriptionInfo)
Diese Methode wird vom SubscriptionManager aufgerufen. Wenn keine Anmeldung der spezifizierten Daten (mehr) vorliegt, bewirkt der Aufruf dieser Methode, dass die entsprechenden Datensätze aus dem Cache entfernt werden.
baseSubscriptionInfo
- Alle Daten, die zu dieser Anmeldeinformationen vorhanden sind, werden aus dem Cache entfernt.public final CachedObject getLastValueOfCachedData(BaseSubscriptionInfo baseSubscriptionInfo, boolean delayedDataFlag)
Gibt den aktuellen Datensatz der spezifizierten Daten zurück. Wenn der Datensatz kein nachgelieferter sein darf, dann wird der letzte nicht nachgeliefert Datensatz zurückgegeben. Ist kein passender Datensatz vorhanden, so wird null
zurückgegeben.
baseSubscriptionInfo
- Anmeldeinformation eines DatensatzesdelayedDataFlag
- Nachgelieferte Datennull
, falls kein Datensatz vorhanden ist.public final java.util.List getCachedData(BaseSubscriptionInfo baseSubscriptionInfo, boolean delayedDataFlag, int n)
Diese Methode iteriert durch den Cache-Inhalt und sammelt die letzen n Datensätze, vom aktuellen Datensatz startend in die Vergangenheit. Wenn keine nachgelieferten erwünscht sind, so werden alle nachgelieferte Daten übersprungen. Ist kein passender Datensatz vorhanden, so wird null zurückgegeben. Sind weniger als n Datensätze vorhanden, so werden diese zurückgegeben.
baseSubscriptionInfo
- Anmeldeinformation eines DatensatzesdelayedDataFlag
- Nachgelieferte Datenn
- Anzahl der gültigen Versionen eines Datensatzesnull
, falls kein Datensatz vorhanden ist. Der Datensatz, der als letztes gecasht wurde steht an Index 0.public final java.util.List getCachedData(BaseSubscriptionInfo baseSubscriptionInfo, boolean delayedDataFlag, long fromTime, long toTime)
Diese Methode iteriert durch den Cache-Inhalt und sammelt die Datensätze, deren Zeitstempel zwischen den spezifizierten Zeiten liegt. Wenn keine nachgelieferten erwünscht sind, so werden alle nachgelieferte Daten übersprungen. Ist kein passender Datensatz vorhanden, so wird null
zurückgegeben.
baseSubscriptionInfo
- Anmeldeinformation eines DatensatzesdelayedDataFlag
- Nachgelieferte DatenfromTime
- Start Zeitintervall. Wird der Wert -1 übergeben, so wird die Datenzeit des zuletzt gecachten Objekts benutzt.toTime
- Ende Zeitintervall. Wird der Wert -1 übergeben, so wird die Datenzeit des zuletzt gecachten Objekts benutzt.null
wenn kein Datensatz vorhanden ist