Threads am Beispiel Parkhaus

M

Montra

Gast
Hallo,

ich versuche mich derzeit an Threads und habe ein paar Schwirigkeiten auf die richtige Idee zu kommen.
Ich wollte zum üben ein Parkhaus simulieren. Hierzu habe ich erstmal eine Klasse Car erstellt. Diese Klasse Car stellt ein Auto dar, es soll zunächst eine zufällige Zeit lang herumfahren und anschließend versuchen mit der Methode enter () ins Parkhaus einzufahren.

Das Parkhaus hat ein Boolean Array mit 10 Slots. Darin wird gespeichert welcher Platz belegt ist und welcher frei ist. Zunächst initialisiere ich dort dieses Array und außerdem ein Array aus 20 Cars.

Die Autos sollen wie schon erwähnt nach einer zufälligen Wartezeit ("rumfahren") versuchen ins Parkhaus zu gelangen, wenn ein Platz frei ist, sollen sie für eine zufällige Zeit dort parken (solange ist dieser Platz natürlich besetzt) und dann wieder aus dem Parkhaus hinaus fahren, wodurch wieder ein Platz frei wird.
Wenn allerdings kein Platz frei ist, soll das Auto für eine zufällige Zeit lang warten und dann erneut versuchen ins Parkhaus zu gelangen.

Ich komme nicht darauf wie ich das genau realisieren kann.

Bisher habe ich das hier:

Car:
Java:
public class Car extends Thread
{
	public int mId;
	
	public Car (int aId)
	{
		mId = aId;
	}
	
	public void run ()
	{
		System.out.println("Auto " + mId + " fährt rum!");
		try
		{
			sleep ((long)Math.random() * 10000);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		System.out.println("Auto " + mId + " will ins Parkhaus!");
	}
	
	public void enter ()
	{
		System.out.println("Auto " + mId + " fährt ins Parkhaus!");
	}
	
	public void carWait ()
	{
		System.out.println("Auto " + mId + " wartet!");
		try
		{
			sleep ((long)Math.random() * 10000);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		System.out.println("Auto " + mId + " versucht es nochmal!");
	}
	
	public void leave ()
	{
		System.out.println("Auto " + mId + " verlässt Parkhaus!");
	}
}

ParkHouse:
Java:
public class ParkHouse 
{
	private boolean[] isFree = new boolean[10];
	Car cars[] = new Car[20];
	
	public void init ()
	{
		for (int i = 0; i < isFree.length; i++)
		{
			isFree[i] = true;
		}
		for (int i = 0; i < cars.length; i++)
		{
			cars[i] = new Car (i+1);
		}
	}
	
	public void open ()
	{
		System.out.println("Das Parkhaus öffnet!");

		
		System.out.println("Das Parkhaus schließt!");
	}
	
	public boolean checkIsFree () 
	{
		for (int i = 0; i < isFree.length; i++)
		{
			if (isFree[i] == true)
			{
				return true;
			}
		}
		return false;
	}
}
 

njans

Top Contributor
Nun du musst generell erstmal den Zugriff auf das ParkHouse Objekt erlauben, damit dort überhaupt Methoden von aufgerufen werden können.
Danach sollten so einige Methoden Synchronisiert werden und du wirst wohl auch synchronized Blöcke brauchen. Ebenfalls fehlen da noch so einige while schleifen (sonst wartet ein Auto ja immer nur ein mal!).

Hilft das schon weiter?
 
M

Montra

Gast
Das ganze soll erstmal ohne Schnickschnack wie synchronized laufen ;)

Mein Problem ist, wie ich alle Autos gleichzeit starten kann und sie quasi (mit Berücksichtigung der Wartezeit) alle gleichzeitig aufs Parkhaus zugreifen wollen. Eine bestimmte Reihenfolge ist völlig egal, Hauptsache jedes Auto schafft es ersmtal einmal zu parken.
 

JavaProfi

Aktives Mitglied
Hi montra,
hier mal eine mögliche rapid code variante.
Vielleicht hilft dir das weiter.

[Java]
public class CarWorld {

static private ParkHouse parkhaus;

public static void main(String[] args) {
parkhaus = new ParkHouse();
for (int id = 1; id <= 20; id++){
new Car(id, parkhaus).start();
}
}

}
[/Java]

[Java]
public class Car extends Thread
{
private int id;
private ParkHouse parkhaus;
private boolean keepAlive = true;

public Car (int id, ParkHouse parkhaus){
this.id = id;
this.parkhaus = parkhaus;
}

public void run ()
{
fahren();
while(keepAlive){
if(einparken() == true){
System.out.println("Auto " + id + " will ins Parkhaus!");
parken();
ausparken();
fahren();
}
else
System.out.println("Auto " + id + ": Parkhaus voll!");
fahren();

if (this.isInterrupted()){
parkhaus.ausparken(this);
keepAlive = false;
}

}
}

private void fahren (){
System.out.println("Auto " + id + " fährt rum!");
warten();

}
private boolean einparken(){
boolean parkTicket = parkhaus.einparken(this);
System.out.println("Auto " + id + " parkt ein!");
return parkTicket;
}

private void parken(){
System.out.println("Auto " + id + " parkt!");
warten();
}

private void ausparken() {
parkhaus.ausparken(this);
System.out.println("Auto " + id + " parkt aus!");
}

private void warten(){
try {
Thread.sleep ((long)Math.random() * 20000);
} catch (InterruptedException e) {
keepAlive = false;
}
}
}
[/Java]

[Java]
public class ParkHouse
{
private Car[] parkboxes;

public ParkHouse (){
parkboxes = new Car[10];
}


public synchronized boolean einparken(Car activeCar)
{
boolean result = false;

for (int i = 0; i < parkboxes.length; i++){
if (parkboxes == null){
parkboxes = activeCar;
result = true;
break;
}
}
return result;
}

public void ausparken(Car activeCar){
for (int i = 0; i < parkboxes.length; i++){
if (parkboxes != null) {
if (parkboxes.equals(activeCar)){
// Parkplatz freigeben
parkboxes = null;
break;
}
}
}
}
}
[/Java]

Gruss
JP
 
Zuletzt bearbeitet:
M

Montra

Gast
@Tobias

Danke für das Beispiel, allerdings arbeitet es mit synchronized, was ich noch nicht einsetzen wollte.
Außerdem macht das Programm keine korrekten Ausgaben, was die Anzahl der Autos in der Werkstatt betifft. Bsp-Ausgabe:

KB-X 123 angenommen!
0
HH-H 666 angenommen!
1
KB-X 123 abgegeben!
2

Nach dem das Auto abgegeben wurde, wurde hier der Count um 1 erhöht. Also scheint dort irgendwas mit der zeitlichen Abstimmung nicht zu klappen.

@Javaprofi

Danke ebenfalls für die Hilfe, jedoch wie bei Tobias mit synchronized :(
 

JavaProfi

Aktives Mitglied
@Tobias

Danke für das Beispiel, allerdings arbeitet es mit synchronized, was ich noch nicht einsetzen wollte.
Außerdem macht das Programm keine korrekten Ausgaben, was die Anzahl der Autos in der Werkstatt betifft. Bsp-Ausgabe:

KB-X 123 angenommen!
0
HH-H 666 angenommen!
1
KB-X 123 abgegeben!
2

Nach dem das Auto abgegeben wurde, wurde hier der Count um 1 erhöht. Also scheint dort irgendwas mit der zeitlichen Abstimmung nicht zu klappen.

@Javaprofi

Danke ebenfalls für die Hilfe, jedoch wie bei Tobias mit synchronized :(

Du kommst um synchronized nicht herum wenn du mit Threads auf einer gemeinsamen Datenstruktur arbeitest!!!

Synchronized ist kein Schnickschnack sondern notwendig!
Gruß
JP
 

Tobias

Top Contributor
Ohne synchronized wird es nicht gehen, außer du baust dir irgendwas mit Hilfe des Concurrent-Packages zusammen (was aber auch nur synchronized in besser versteckt ist).

Die "falschen" Ausgaben entstehen durch die Verwendung des Postfix-Operators "++" bzw "--" und haben nichts mit der zeitlichen Abfolge zutun.
 

Lumaraf

Bekanntes Mitglied
[Java]
public class ParkHouse
{
/* ... */

public void ausparken(Car activeCar){
for (int i = 0; i < parkboxes.length; i++){
if (parkboxes != null) {
if (parkboxes.equals(activeCar)){
// Parkplatz freigeben
parkboxes = null;
break;
}
}
}
}
}
[/Java]


Die Methode ParkHouse#ausparken kann btw eine NullPointerException liefern wenn zwischen beiden if Abfragen von einem anderen Thread der entsprechende Index auf null gesetzt wird. Man muß an allen Stellen an denen mehrere Threads veränderbare Daten zugreifen können in irgendeiner Weise die Zugriffe untereinander koordinieren. (mittels synchronized oder einer passenden Klasse aus java.util.concurrent)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
C Threads und Swing Java Basics - Anfänger-Themen 9
berserkerdq2 Wo finde ich in der Java Api die Notation zu Threads bezüglich Synchronized? Java Basics - Anfänger-Themen 14
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
B Monitor als Schranke von Threads Java Basics - Anfänger-Themen 20
W Threads Alphabet Java Basics - Anfänger-Themen 20
H Threads Anfänger Java Basics - Anfänger-Themen 17
1 Threads parallel laufen Java Basics - Anfänger-Themen 11
B Threads Problem mit mehreren Threads Java Basics - Anfänger-Themen 38
M Threads Java Basics - Anfänger-Themen 12
L Threads Synchronisierung zwischen threads Java Basics - Anfänger-Themen 4
M Threads Java Basics - Anfänger-Themen 2
A Threads Java Basics - Anfänger-Themen 9
A Threads Java Basics - Anfänger-Themen 13
A Threads und .join Java Basics - Anfänger-Themen 14
W Threads starten Java Basics - Anfänger-Themen 2
X Threads Zwei Threads, aber doppelte Ausgabe verhindern (synchronized) Java Basics - Anfänger-Themen 54
J Wieviele threads? Java Basics - Anfänger-Themen 9
J Problem bei seriellem Start von Threads Java Basics - Anfänger-Themen 11
O Threads Java Basics - Anfänger-Themen 2
L Buchungssystem und Threads Java Basics - Anfänger-Themen 2
O Threads - Synchronize(), join(), wait(), notify(), yield() Java Basics - Anfänger-Themen 6
L Klassen NFC Reader und JavaFx Problem -> threads? Java Basics - Anfänger-Themen 2
A Kommunikation zwischen nebenläufigen Threads Java Basics - Anfänger-Themen 4
S Gemeinsame Ressource und Mehrfachinstanziierung von Threads Java Basics - Anfänger-Themen 16
S Verklemmung Threads Java Basics - Anfänger-Themen 11
B Threads 2 Threads gleichzeitig laufen lassen Java Basics - Anfänger-Themen 1
M Threads Threads laufen sequenziell, statt gleichzeitig. Java Basics - Anfänger-Themen 9
M Threads run Methode Java Basics - Anfänger-Themen 4
javajoshi mehrere Threads: Methoden zentral unterbringen Java Basics - Anfänger-Themen 8
javajoshi Problem mit zwei Threads und Arrays (Runnable) Java Basics - Anfänger-Themen 12
L Threads Mit Threads JLabel ändern! Java Basics - Anfänger-Themen 2
K Matrixen berechnen nach Worker Master Paradigma mit Threads Java Basics - Anfänger-Themen 4
S Kleine Frage zu Threads Java Basics - Anfänger-Themen 3
M Mit 2 Threads eine Zahl hochzählen Java Basics - Anfänger-Themen 13
T Threads Synchronisieren Java Basics - Anfänger-Themen 6
D Frage Threads Java Basics - Anfänger-Themen 6
Z Threads Executor Framework - Aufgabe auf n Threads aufteilen Java Basics - Anfänger-Themen 10
Z Threads Threads - Zugriff auf Ressourcen ohne(Lock, Synchronized) Java Basics - Anfänger-Themen 2
kilopack15 Verständnisfrage zur Verwendung von notify() bei Threads Java Basics - Anfänger-Themen 2
kilopack15 Mehrere Threads in einer Klasse Java Basics - Anfänger-Themen 8
H Threads funktionieren nicht Java Basics - Anfänger-Themen 4
J Aufgabe(Threads) richtig verstanden/implementiert Java Basics - Anfänger-Themen 27
R Threads aufeinander warten lassen? Java Basics - Anfänger-Themen 10
T Threads Durch threads gestartete Prozesse killen Java Basics - Anfänger-Themen 2
J Threads Java Basics - Anfänger-Themen 38
D Alte Klausuraufgabe Threads Java Basics - Anfänger-Themen 10
A Threads Threads bestimmte Aufgaben zuweisen... Java Basics - Anfänger-Themen 3
R Threads in JavaFX Java Basics - Anfänger-Themen 3
E Threads Doppelte Threads beenden Java Basics - Anfänger-Themen 4
F Sicheres Zurückmelden aus Threads Java Basics - Anfänger-Themen 0
G Threads zum Thema Threads??? null Ahnung Java Basics - Anfänger-Themen 4
Q Threads Threads in Swing Anwendungen Java Basics - Anfänger-Themen 5
J ConcurrentCalculation Multi Threads in Java Java Basics - Anfänger-Themen 3
P Threads Trotz Threads wird nur 1 Prozessorkern ausgelastet Java Basics - Anfänger-Themen 7
M "restartable" threads Java Basics - Anfänger-Themen 11
M Threads - summieren Java Basics - Anfänger-Themen 13
W Klassen Variable einer anderen Klasse ändern (Threads) Java Basics - Anfänger-Themen 3
E Threads - Programm analysieren Java Basics - Anfänger-Themen 2
E join() bei zwei Threads Java Basics - Anfänger-Themen 2
T Threads Threads richtig synchronisieren Java Basics - Anfänger-Themen 3
D [Concurrency/Threads] Code Umsetzung Schriftlich Java Basics - Anfänger-Themen 2
D Threads Java Basics - Anfänger-Themen 4
M Threads nio Dateien kopieren, Threads und Gui Java Basics - Anfänger-Themen 0
N Verweise auf Variablen in verschiedenen Threads Java Basics - Anfänger-Themen 4
T Java-Threads Java Basics - Anfänger-Themen 0
G Moving Objects with Threads (implements Runnable) Java Basics - Anfänger-Themen 1
F Threads funktionieren auf JPanel nicht Java Basics - Anfänger-Themen 1
M Problem mit Threads Java Basics - Anfänger-Themen 11
M Threads - wo gehören sie hin? Java Basics - Anfänger-Themen 3
S 2D-Spiel mit Threads... Java Basics - Anfänger-Themen 3
J Threads Java Basics - Anfänger-Themen 3
F ExecutorService und offene Threads Java Basics - Anfänger-Themen 3
P Threads Threads nicht nebenläufig Java Basics - Anfänger-Themen 7
M Threads nicht nebenleblaufig Java Basics - Anfänger-Themen 2
B Threads parallel zur main Java Basics - Anfänger-Themen 3
M Threads Java Basics - Anfänger-Themen 2
M Threads, zwei methoden gleichzeitig laufen lassen Java Basics - Anfänger-Themen 4
M Threads und Methodenübergreifender Variablezugriff Java Basics - Anfänger-Themen 2
J Wie handle ich Threads am besten? Java Basics - Anfänger-Themen 2
H Threads Java Basics - Anfänger-Themen 10
B synchronized threads Java Basics - Anfänger-Themen 17
E Mehrmaliges Ausführen eines Threads Java Basics - Anfänger-Themen 5
E Threads Verständnisfrage bzgl. Threads und Sleep Java Basics - Anfänger-Themen 2
T Alle Threads .notify() Java Basics - Anfänger-Themen 13
R Threads Verständnisschwierigkeit Java Basics - Anfänger-Themen 2
J Können mehere Threads parallel eine Datei lesen? Java Basics - Anfänger-Themen 4
G Methoden in Threads wandeln Java Basics - Anfänger-Themen 7
H Threads Java Basics - Anfänger-Themen 17
F Java Concurrency - Threads Java Basics - Anfänger-Themen 4
V Threads Threads synchronisieren Java Basics - Anfänger-Themen 4
T Threads Join() = Block? oO Java Basics - Anfänger-Themen 4
J Threads ArrayList Problem bei Threads Java Basics - Anfänger-Themen 3
C Objekte durchschleifen / Threads Java Basics - Anfänger-Themen 2
J Threads stoppen mit interrupt - Frage dazu Java Basics - Anfänger-Themen 7
N Pingen in Threads Java Basics - Anfänger-Themen 9
B Threads benutzen Java Basics - Anfänger-Themen 5
E Allgemein Verständnissfrage zum Ablauf mehrerer Threads Java Basics - Anfänger-Themen 4
S Threads erzeugen Java Basics - Anfänger-Themen 11
K Threads Nur 2 von 3 Threads funktionieren Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben