Interface QueueSerializer<E>

All Known Implementing Classes:
ByteQueueSerializer, IntQueueSerializer, LongQueueSerializer, ObjectQueueSerializer, ShortQueueSerializer, StringQueueSerializer

public interface QueueSerializer<E>
Ein Interface, das Objekte kapselt, die der FileBackedQueue dabei helfen, Objekte auf die Festplatte zu serialisieren.
  • Method Summary

    Modifier and Type Method Description
    E deserialize​(java.io.DataInputStream inputStream)
    Deserialisiert ein Objekt aus dem Stream.
    int getSize​(E object)
    Gibt die Größe eines Objektes an.
    void serialize​(java.io.DataOutputStream outputStream, E object)
    Serialisiert das Objekt
  • Method Details

    • getSize

      int getSize​(E object)
      Gibt die Größe eines Objektes an. Es ist wichtig, dass hier exakt die Länge zurückgegeben wird, die in den outputStream geschrieben werden, würde man serialize(outputStream, object) mit dem gleichen Objekt aufrufen.
      Parameters:
      object - Objekt
      Returns:
      Größe des serialisierten Objektes in Bytes
    • serialize

      void serialize​(java.io.DataOutputStream outputStream, E object) throws java.io.IOException
      Serialisiert das Objekt
      Parameters:
      outputStream - In diesen Stream soll das Objekt geschrieben werden. Es muss an die aktuelle Stream-Position geschrieben werden und es müssen so viele Bytes geschrieben werden, wie getSize(objekt) zurückgeben würde.
      object - Objekt, das geschrieben werden soll
      Throws:
      java.io.IOException - Falls beim Schreiben Fehler auftreten
    • deserialize

      E deserialize​(java.io.DataInputStream inputStream) throws java.io.IOException
      Deserialisiert ein Objekt aus dem Stream. Es muss an der aktuellen Stream-Position gelesen werden und zwar so viele Bytes, wie das deserialisierte Objekt in der getSize()-Funktion zurückliefern würde. Damit vor dem Deserialisieren bekannt ist, wie viele Bytes gelesen werden sollen, ist es bei Typen variabler Länge evtl. nötig beim Serialisieren zuerst die Länge zu schreiben und beim Deserialisieren als erstes zu lesen.
      Parameters:
      inputStream - Eingabestream.
      Returns:
      Das deserialisierte Objekt
      Throws:
      java.io.IOException - Falls beim Lesen Fehler auftreten