Probleme mit Array

Status
Nicht offen für weitere Antworten.
L

LexDanny

Gast
Hallo!

Ich habe einen Array, für den ich (zwecks Zeitvergleich mit einer Queue) in einer for-Schleife einen Wert hinzufüge und gleich wieder lösche.

Zeittest.java:
Java:
Array q1  = new Array(1000);     
Object o1 = new Object();
Object g = new Object();
g="";
for (int i=1; i<500; i++)
	{
	q1.addFirst(o1);
	}
double time_before1 = System.currentTimeMillis();
for (int j=1; j<=10000; j++)
	{
	q1.removeFirst();
	q1.addFirst(g);
	}
double time_after1 = System.currentTimeMillis();
double time1= time_after1-time_before1;
System.out.print("Die 2. Schleife dauerte: " +time1+ " Sekunden");

Die Funktionen removeFirst(), addFirst etc. sind definiert und funktionieren auch einwandfrei. Bei der Queue sieht es änhlich aus, nur dass halt q eine Queue ist. Und der Queue Ablauf funktioniert!
Das Probleme ist in der for-Schleife bei j. Wenn j<=500 funktioniert das Ganze. Allerdings braucht die Schleife dann so wenig Zeit, dass sich ein Vergleich nicht lohnt. Also wollte ich das öfter durchlaufen lassen. Müsste meines Erachtens nach auch funktionieren, da ja immer das selbe Element bzw. am selben Index entfernt und hinzugefügt wird. Allerdings kommt eine Exception, dass der Array voll ist. Das kann ja aber nur auftreten, wenn das entfernen nicht klappt.

Hier die Datei Deque.java
Java:
public interface Deque{
	    int capacity();
	    int size();
	    void clear();
	    void addFirst(Object e) throws DequeFull;
	    void addLast(Object e) throws DequeFull;
	    Object removeFirst() throws DequeEmpty;
	    Object removeLast() throws DequeEmpty;
}
	
class DequeFull extends Exception {
	private static final long serialVersionUID = 1L;
	
}
class DequeEmpty extends Exception {
	private static final long serialVersionUID = 1L;
	
}

und Array.java:
Java:
public class Array implements Deque{
	int anzahl;
	int max_Anzahl;
	int first;
	int last;
	
	Object[] list;
	
	public Array(int max_A) { 
		max_Anzahl=max_A;
		first = 1;
		anzahl = 0;
		list = new Object[max_Anzahl];
		last =  list.length -1;
	}
	
	public int capacity(){
		return max_Anzahl;
	}
	
	public int size(){
		return anzahl;
	}
	
	public void clear(){
		first = 1;
		last =  list.length;
		anzahl = 0;
		
	}
	
	public void addFirst(Object e) throws DequeFull{
		
		if (anzahl == list.length)
			throw new DequeFull();
		
		anzahl++;
		
		int index = first-1;
		
		if (index <0)
			index = list.length -1;
		
		first = index;
		list[index] = e;
		
		if (anzahl == 1)
			last = index;
	}
	
	public void addLast(Object e) throws DequeFull{
		
		if (anzahl == list.length)
			throw new DequeFull();
		
		anzahl++;
		
		int index = last +1;
		
		if (index >= list.length)
			index = 0;
		
		last = index;
		list[index] = e;
		
		if (anzahl==1)
			first = index;
		
	}
	
	public Object removeFirst() throws DequeEmpty{
		
		if (anzahl == 0)
			throw new DequeEmpty();
		
		Object element = list[first];
		first = first +1;
		
		if (first>list.length)
			first = 0;
		

		return element;
	}
	
	public Object removeLast() throws DequeEmpty{
		
		if (anzahl == 0)
			throw new DequeEmpty();
		
		Object element = list[last];
		last = last -1;
		
		if (last<0)
			last= list.length -1;
		
		return element;
	}
}

Jemand eine Idee woran das liegt?
Danke im Vorraus
 
L

LexDanny

Gast
Ja, wirklich!

Exception in thread "main" de.uni_potsdam.hpi.DequeFull
at de.uni_potsdam.hpi.Array.addFirst(Array.java:35)
at de.uni_potsdam.hpi.Zeittest.main(Zeittest.java:13)
 
S

SlaterB

Gast
> Allerdings kommt eine Exception, dass der Array voll ist. Das kann ja aber nur auftreten, wenn das entfernen nicht klappt.

in der Schleife mit addFirst() wird doch nichts entfernt, wenn voll ist dann Exception,
was genau ist daran ein Problem?
 
M

maki

Gast
Ach so...

Wolltest du eigentlich mit max_Anzahl vergleichen oder wirklich mit anzahl?

Nebenbei, die Code Konventionen für Java sollten schon eingehalten werden, allein der lesbarkeit wegen, deutsche Bezeichner in Java führen unweigerlich zu denglisch ;)
 
L

LexDanny

Gast
@slaterB: In der Schleife wird das 1. Element aber entfernt! Oder meinst du etwas anderes?
[Java]
for (int j=1; j<=10000; j++)
{
q1.removeFirst();
q1.addFirst(g);
}
[/code]
Und daher kann doch der Array gar nicht voll werden. Verstehst du was ich meine?


@maki: Wo bist du gerade (max_Anzahl)? Also welchen Vergleich meinst du?
 
Zuletzt bearbeitet von einem Moderator:

Michael...

Top Contributor
Bist Du Dir sicher, dass Deine remove Methoden so funktionieren? Mir ist auch nicht so ganz klar was Du da genau vorhast.
 
L

LexDanny

Gast
Naja ich denke schon(korrigiert mich, wann ich falsch liege). Hatte eine Test.java in der halt getestet wurde, wenn x Elemente im Array sind und ein y angefügt wird(addLast) und dann x-mal removefirst und dann das nächste removefirst dem y entspricht.... Also denke ich mal, dass es geht.
 
S

SlaterB

Gast
in beiden remove wird anzahl nicht gesenkt

> Oder meinst du etwas anderes?

ich dachte erst, es ginge um die erste Schleife, die initial befüllt
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
N Probleme bei Speicherung eines Integer-Array in Datei speichern Java Basics - Anfänger-Themen 3
B Probleme beim einlesen einer short variablen für einen Array Java Basics - Anfänger-Themen 1
J Shakersort, das Array macht Probleme! Java Basics - Anfänger-Themen 4
C Erste Schritte Array Werte Ausgeben Probleme mit variable Java Basics - Anfänger-Themen 21
C Probleme beim Array Java Basics - Anfänger-Themen 6
T probleme mit array Java Basics - Anfänger-Themen 4
B Vererbung Probleme bei Array und Vererbung Java Basics - Anfänger-Themen 7
M Datentypen Char Array in String Array gibt Probleme Java Basics - Anfänger-Themen 10
M Collections Probleme bei Zugriff auf Array Java Basics - Anfänger-Themen 19
T Anfänger hat Probleme mit Array einlesen ;) Java Basics - Anfänger-Themen 13
L 5 Gewinnt Array[][] probleme Java Basics - Anfänger-Themen 20
F Probleme mit Array bzw. ArrayList Java Basics - Anfänger-Themen 26
D Probleme mit Array Java Basics - Anfänger-Themen 8
S Probleme mit Array Java Basics - Anfänger-Themen 13
J Probleme mit setIcon bei Button-Array Java Basics - Anfänger-Themen 4
H String Array Probleme Java Basics - Anfänger-Themen 10
D "Ueber"-Klasse? / Label Array Probleme Java Basics - Anfänger-Themen 2
M probleme mit array (als attribut einer klasse) Java Basics - Anfänger-Themen 2
M Probleme mit Array's Java Basics - Anfänger-Themen 6
R probleme mit array Java Basics - Anfänger-Themen 17
megachucky probleme mit einem char-array. Java Basics - Anfänger-Themen 6
A Probleme bei Ausgabe (array) Java Basics - Anfänger-Themen 2
C Probleme mit Array Java Basics - Anfänger-Themen 2
N Große Probleme mit StingBuffer und Array Java Basics - Anfänger-Themen 2
D Probleme bei Verwendung short und int im Constuctor Java Basics - Anfänger-Themen 6
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben