Class FileLock

java.lang.Object
de.bsvrz.sys.funclib.filelock.FileLock

public class FileLock
extends java.lang.Object
Diese Klasse stellt einen Mechanismus zur Verfügung, mit dem geprüft werden kann, ob sich eine Datei im Zugriff einer anderen Applikation befindet, die ebenfalls diesen Mechansimus verwendet.

Damit oben beschriebene Aufgabe realisiert werden kann, wird im Konstruktor der Klasse eine Datei angegeben, die gegen unerlaubten Zugriff geschützt werden soll. Soll die übergebene Datei geschützt werden, wird eine entsprechende Methode aufgerufen. Dieser Methodenaufruf prüft, ob eine Datei mit der Endung ".lock" existiert, der restliche Pfad ist gleich der zu schützenden Datei.

Ist so eine Datei vorhanden, wird eine Exception geworfen, da sich zu schützende Datei bereits im Zugriff befindet.

Kann eine Datei angelegt werden, wird der Methodenaufruf keine weiteren Auswirkungen habe. Legt eine zweite Applikation eine Instanz dieser Klasse an und übergibt die gleiche Datei im Konstruktor und ruft die Methode zum sperren der Datei auf, wird automatisch eine Exception geworfen.

Die Klasse enthält ebenfalls eine Methode zum löschen der Datei mit der Endung ".lock". Wurde die Datei gelöscht, können andere Applikationen die Datei wieder sperren.

  • Constructor Summary

    Constructors
    Constructor Description
    FileLock​(java.io.File protectedFile)
    Legt ein Objekt an, die übergebene Datei wird nicht gegen den Zugriff gesichert.
  • Method Summary

    Modifier and Type Method Description
    void lock()
    Zeigt an, dass die im Konstruktor übergebene Datei im Zugriff einer Applikation ist.
    void unlock()
    Gibt die Datei, die im Konstruktor übergeben wurde wieder frei.

    Methods inherited from class java.lang.Object

    clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
  • Constructor Details

    • FileLock

      public FileLock​(java.io.File protectedFile)
      Legt ein Objekt an, die übergebene Datei wird nicht gegen den Zugriff gesichert. Dies muss explizit mit dem Aufruf von lock() geschehen.
      Parameters:
      protectedFile - Datei, die gesperrt werden soll.
  • Method Details

    • lock

      public void lock() throws java.io.IOException
      Zeigt an, dass die im Konstruktor übergebene Datei im Zugriff einer Applikation ist. Jeder weitere Aufruf ohne vorher unlock() aufzurufen wird zu einer IllegalStateException führen.
      Throws:
      java.lang.IllegalStateException - Die Datei wurde bereits gesperrt und befindet sich somit im Zugriff.
      java.io.IOException
    • unlock

      public void unlock()
      Gibt die Datei, die im Konstruktor übergeben wurde wieder frei. Nach Aufruf dieser Methode kann die Methode lock() wieder aufgerufen werden.