ARRAY/List die sich immer wieder von vorne neu auffüllt ?

rIpP3r

Mitglied
Hey ;),
also ich habe folgendes Problem:

Ich arbeite momentan an einem Projekt dass immer 10 bestimmte Daten (long werte) speichern soll.
d.h Sagen wir ich bekomme jede minute einen neuen Datensatz, hab ich erst 9 wird ein 10 dazu geschrieben. Hab ich schon 10 wird der erste Datensatz (automatisch) wieder überschrieben.
Gibt es dafür schon eine passende Implementierung? (irgend eine Array/List Art von der ich nix weis?)
Ich hoffe ihr versteht was ich meine ;)
Danke schonmal.
Lg
Gast
 

XHelp

Top Contributor
Bekannt ist mir sowas nicht, aber es ist ja leicht es selber zu machen:
du merkst dir die "aktuelle Position" und schreibst an die
Code:
(i+1)%10
-Stelle
Optional kannst du vllt. an Queue schrauben.
 
G

Gast2

Gast
Was du suchst ist ein RingBuffer. Eine fertige Implementierung gibts in der StandardAPI glaube ich nicht, aber google liefert dir da schon nen paar Sourcecodes.
 
G

Gast2

Gast
Von ner ArrayList ableiten, hm... fänd ich nicht so schön.
Das eingängiste wäre mit nem einfachen Array zu arbeiten. Nen Ringbuffer hat nunmal die Eigenschaft eine feste Größe zu haben die sich in der Regel nicht so schnell ändert.
Ich würde also nen Array mit 2 Zeigern versehen und fertig :)
 
G

Gast2

Gast
du brauchst einen zeiger damit du weißt wo das nächste element gespeichert werden muss, und einen zweiten zeiger der dir anzeigt an welcher stelle als nächstes gelesen werden soll. (z.b. bei nem fifo buffer).
 

XHelp

Top Contributor
Man kommt eigentlich mit einem Zeiger aus.
Wie gesagt
Code:
curPos = (curPos+1)%10
wäre der Zeiger auf das zuletzt geschriebes Element und um i-tes (der Älteste Eintrag ist der 0.) Element zu lesen musst du
Code:
(curPos + 1 + i)%10
lesen.
(wobei man noch unterscheiden musste, ob alle 10 Einträge existieren, oder nicht)
 
G

Gast2

Gast
Du brauchst ja zumindest schonmal die Informationen an welcher Stelle du gerade stehst und wieviele Elemente in deinem Buffer sind. Ich denke mit weniger Informationen kommst du nicht aus, oder hast du da ne idee?

Java:
public class RingBuffer<E> {

    private E[] items;
    private int size;
    private int last = 0;

    public RingBuffer() {
        this(10); // default size is 10
    }

    public RingBuffer(int capa) {
        items = (E[]) new Object[capa];
    }

    public void push(E item) {
        if (getSize() == items.length) {
            throw new IndexOutOfBoundsException("buffer overflow");
        }

        items[last] = item;
        last = (last + 1) % items.length;
        size++;
    }

    public E pop() {
        if (getSize() == 0) {
            throw new IndexOutOfBoundsException("buffer underflow");
        }

        int first = (last - size + items.length) % items.length;
        E item = items[first];
        size--;

        return item;
    }

    public int getSize() {
        return size;
    }

    public static void main(String[] args) {
        RingBuffer<Integer> buffer = new RingBuffer<Integer>(5);
       
        buffer.push(1);
        buffer.push(2);
        buffer.push(3);
        buffer.push(4);
        buffer.push(5);

        try {
            buffer.push(6);
        } catch (IndexOutOfBoundsException ioobe) {
            System.out.println("oops: " + ioobe);
        }
        
        try {
            while (true) {
                System.out.println("pop: " + buffer.pop());
            }
        } catch (IndexOutOfBoundsException ioobe) {
            System.out.println("oops: " + ioobe);
        }
    }
}
 

XHelp

Top Contributor
Öhm, warum ist das RingBuffer, wenn du ein buffer overflow schmeißt? oO
Ich dachte eher an sowas:
Java:
public class RingArray<E> {

	private E[] list;
	private int last;
	private int size;

	public RingArray(int max) {
		list = (E[]) new Object[max];
		last = -1;
		size = 0;
	}

	public void add(E item) {
		last = (last + 1) % list.length;
		list[last] = item;
		if (size < list.length) {
			size++;
		}
	}

	public E get(int index) {
		if (size == 0) {
			return null;
		}
		return list[(last + index + 1) % size];

	}

	public int getSize() {
		return size;
	}

	public static void main(String[] args) {
		RingArray<Integer> testArray = new RingArray<Integer>(5);
		testArray.add(1);
		testArray.add(2);
		testArray.add(3);

		System.out.println("0: " + testArray.get(0)); // muss 1 sein
		System.out.println("1: " + testArray.get(1)); // muss 2 sein

		testArray.add(4);
		System.out.println("0: " + testArray.get(0)); // muss immer noch 1 sein
		testArray.add(5);
		testArray.add(6);
		System.out.println("0: " + testArray.get(0)); // muss nun 2 sein
	}

}
 
M

maki

Gast
Man könnte ja zB. auch eine ArrayBlockingQueue verwenden, wenn sie 10 Elemente hat, wird eben das erste entfernt bevor eine neues hinzugefügt wird.
 
G

Gast2

Gast
Öhm, warum ist das RingBuffer, wenn du ein buffer overflow schmeißt? oO
Weils in meinen Augen wenig sinn macht wenn man sich die eigenen Daten überschreibt. Ein Buffer soll die Daten zwischenspeichern bis man Zeit hat diese zu verarbeiten. Es hat ja keinen Sinn wenn in der Wartezeit die Hälfte der Daten verloren geht :p
 
G

Gast2

Gast
Ok ich hatte jetzt nur an die Bereiche gedacht wo es notwendig ist dass keine Daten verloren gehen, aber ihr habt recht, es gibt durchaus auch anwendungsbereiche wo einen nur die letzten x datensätze interessieren.

Sonst sind ja die ganzen module-Rechnungen sinnlos.
Nicht wirklich, dadurch dass die Zeiger immer auf den Anfang und das Ende der Daten anzeigen spart man sich ständiges umkopieren der Daten an den Anfang.

EDIT:
RingBuffer 2.0
Java:
public class RingBuffer<E> {

    private E[] items;
    private int size = 0;
    private int last = 0;

    private boolean overrideData = true;
    
    public RingBuffer() {
        this(10); // default size is 10
    }

    public RingBuffer(int capa) {
        items = (E[]) new Object[capa];
    }

    public void push(E item) {
        if (!overrideData && getSize() == items.length) {
            throw new IndexOutOfBoundsException("buffer overflow");
        }

        items[last] = item;
        last = (last + 1) % items.length;
        size = Math.min((size+1), items.length);
    }

    public E pop() {
        if (getSize() == 0) {
            throw new IndexOutOfBoundsException("buffer underflow");
        }

        int first = (last - size + items.length) % items.length;
        E item = items[first];
        size--;

        return item;
    }

    public int getSize() {
        return size;
    }

    public boolean isOverrideData() {
        return overrideData;
    }

    public void setOverrideData(boolean overrideData) {
        this.overrideData = overrideData;
    }
}
 
Zuletzt bearbeitet von einem Moderator:

XHelp

Top Contributor
Nicht wirklich, dadurch dass die Zeiger immer auf den Anfang und das Ende der Daten anzeigen spart man sich ständiges umkopieren der Daten an den Anfang.
Ja, sry, hab deine Funktionsweise zuerst ein wenig falsch verstanden.
Aber
[JAVA=30]
int first = (last - size + items.length) % items.length;
[/code]
hier kann items.length in der Klammer weg.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
J Array.list vergleichen Java Basics - Anfänger-Themen 1
L Datentypen Array List Java Basics - Anfänger-Themen 9
J String Array zu Map<Character, List<Character>> mit Streams Java Basics - Anfänger-Themen 1
W Stream Array List - Frage Java Basics - Anfänger-Themen 5
X Array List geordnet ausgeben. (JSF und JAVA) Java Basics - Anfänger-Themen 1
E Array-list mit einer bestimmten Länge Java Basics - Anfänger-Themen 17
M Methode überladen - Array List Java Basics - Anfänger-Themen 5
L Linked List - Array List Java Basics - Anfänger-Themen 2
D Bestimmten Wert aus Array List ausgeben Java Basics - Anfänger-Themen 7
P Anlegen und Abfragen von Array List Java Basics - Anfänger-Themen 4
C Array List mit String vergleichen und Fehlermeldung ausgeben Java Basics - Anfänger-Themen 6
F Wozu braucht man array list? Java Basics - Anfänger-Themen 29
M Array List ausgeben Java Basics - Anfänger-Themen 13
A List Array - wie instanzieren Java Basics - Anfänger-Themen 7
S Einen neuen String ohne Array oder List erzeugen??? Java Basics - Anfänger-Themen 13
J Array List - Über die Konsole eingeben Java Basics - Anfänger-Themen 1
M Array List Objekt Entfernen Java Basics - Anfänger-Themen 15
-horn- Doppelte Einträge entfernen, aus Array, List oder sonstwas Java Basics - Anfänger-Themen 9
I viele Dateinamen in ein String-Array mit File().list() Java Basics - Anfänger-Themen 4
B Java Array List größe auslesen zur Suchfunktion Java Basics - Anfänger-Themen 5
P guck ob Element in Array List enthalten ist Java Basics - Anfänger-Themen 2
G Array List sortieren / auswerten Java Basics - Anfänger-Themen 24
D Dyn Array oder Array List Java Basics - Anfänger-Themen 10
G Min und Max Wert aus Array List lesen Java Basics - Anfänger-Themen 3
G array list - identifier expected Java Basics - Anfänger-Themen 4
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben