Skip to main content

So lassen sich Java Strings vergleichen

Du willst in Java Strings vergleichen – Kein Problem.

So geht’s.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = new String ("Apfel");
		String frucht2 = new String ("Apfel");
		
		if (frucht1 =="Apfel"){
			System.out.println("Es ist ein Apfel");
		}
		else {
			System.out.println("Es ist eine Birne");
		}
	}
}

Na, welche Bildschirmausgabe wird hier zurückgeworfen?
Ja – Birne.
Und das obwohl ganz klar die gleichen Textwerte geprüft werden.

Aber es wird noch verrückter.
Probiere den Code aus.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = new String ("Apfel");
		String frucht2 = new String ("Apfel");
		
		if (frucht1 ==frucht2){
			System.out.println("Zwei Äpfel");
		}
		else {
			System.out.println("Früchte sind unterschiedlich");
		}
	}
}

Selbst hier bekommst du die zweite, also die falsche, Meldung zurück.

Lass uns noch einen Code probieren.
Versprochen – diese Irreführung hört gleich auf. 🙂

Es werden jetzt beide String-Objekte nicht über den Konstruktor angelegt.
Und es erfolgt eine einfache Zuweisung der Textwerte.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";
		String frucht2 = "Apfel";
		
		//Prüfung 1
		if (frucht1=="Apfel"){
			System.out.println("Es ist ein Apfel");//Diese Ausgabe erscheint
		}
		else {
			System.out.println("Es ist eine Birne");
		}
		
		//Prüfung 2
		if (frucht1 ==frucht2){
			System.out.println("Zwei Äpfel");//Diese Ausgabe erscheint
		}
		else {
			System.out.println("Früchte sind unterschiedlich");
		}
	}
}

Jetzt bekommst du die richtigen Konsolenausgaben zurück.

Was ist passiert?
Ich plädiere auf reine Java-Willkür. 🙂

Nein es ist nur Spaß und dahinter steckt wirklich ein nützliches Konzept.

Wenn du Java Strings vergleichst, ist das wirklich so – als würdest du Äpfel und Birnen vergleichen.

Denn Strings sind echte Java Objekte.

Und die Variablen frucht1 und frucht2 sind keine Objekte.
Es sind lediglich Referenzvariablen, welche eine Speicheradresse beinhalten.

Und String Objekte, welche du über einen Konstruktor erzeugst – landen auf dem Heap.
Das ist das Speichersystem für alle Java Objekte.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = new String ("Apfel");//wird auf dem Heap verwaltet
		String frucht2 = new String ("Apfel");//wird auf dem Heap verwaltet
		}
	}

Und so kannst du dir dann deine Objekte im Heap-Speicher vorstellen.

Java-Strings-Apfel

Und die Referenzvariablen würden dann lediglich als Wert die Speicheradresse tragen.
Java Strings Referenzen Adressen

Und wenn du jetzt frucht1 mit frucht2 vergleichst.
Dann vergleichst du nur ob die Adresse des ersten Objektes mit der Adresse des zweiten Objektes übereinstimmt.
Java Strings Verweise if

Und da beide Adressen nicht übereinstimmen, würde dieser Code nicht funktionieren.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = new String("Apfel");// wird auf dem Heap verwaltet
		String frucht2 = new String("Apfel");// wird auf dem Heap verwaltet

		// Intern wird geprüft ob Speicherplatz 001 == 002 ist
		if (frucht1 == frucht2) {
			System.out.println("Es ist ein Apfel");
		} else {
			System.out.println("Es ist eine Birne");
		}
	}
}

Anders ist es mit den String-Objekten, welche ohne Konstruktor erstellt werden.

Diese landen nämlich nicht in diesem Speichersystem.
Sie landen in einem string-optimierten Speichersystem.
Dem String Pool.

String Pool – was ist das?
Java ist schlau und sagt sich:

„Wieso soll ich zweimal das selbe Objekt erschaffen und dieses mit kostbaren Speicher ausstatten.“

„Ist es nicht viel besser ein Objekt zu erschaffen und sobald ich bemerke, dass noch ein Objekt mit selben Textwert entsteht – verweise ich nur noch darauf.“

„Dann habe ich zwar zwei Verweise, aber nur ein Objekt.“

Und genau das passiert auch, wenn du Strings anlegst ohne den Konstruktor aufzurufen.
Diese landen im Pool.

Java Strings Pool Adressen

Und dieser Pool ist ein Unterspeichersystem des Heapspeicher.
Der Pool hat somit auch Adressen.

Aber alle gleichen String-Objekte, welche in den Pool kommen – landen bei der selben Adresse.
Es verweisen dann zwei Variablen auf ein- und dasselbe Objekt und somit auf dieselbe Adresse.

Java Strings Pool gleiche Adressen

Wichtig ist:
Java macht das selbstständig für dich.
Du legst ein String-Objekt an.
Java prüft, ob es schon genau den selben Text im Pool gibt.
Falls ja – verweist Java die Referenzvariable an die entsprechende Adresse im Pool.

Ein Birnen-String würde dann in Speicher 2 landen.
Und alle Referenzvariablen mit dem Textwert „Birne“ würden auf Speicherplatz 2 zeigen.
Ein Pfirsich in drei. usw.

Also Referenzvariablen mit gleichen Textwert zeigen auf ein- und dasselbe Objekt im Pool.
Und somit wäre Birne gleich Birne und Apfel gleich Apfel.

Dann würde sich eine Prüfung der Werte als richtig einstellen.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";// wird im Pool verwaltet
		String frucht2 = "Apfel";// wird im Pool verwaltet

		// Intern wird geprüft ob Speicherplatz Pool-001 == Pool-001 ist
		if (frucht1 == frucht2) {
			System.out.println("Es ist ein Apfel");
		} else {
			System.out.println("Es ist eine Birne");
		}
	}
}

Ja- so könnte man Strings vergleichen.

Du merkst es – die Betonung liegt auf könnte.
Denn es ist nur ein Vergleich auf Speicheradressen.

Viel besser wäre es doch den String Buchstaben für Buchstaben zu durchlaufen und zu prüfen.

Und das mit eine Schleife.

Keine Angst die gibt es schon.
Die Methode heißt equals.

Und jedes Objekt, also auch die Strings können diese Methode nutzen.
Dazu einfach:

  1. Den Namen der Referenzvariablen schreiben „frucht1“
  2. Den Punkt setzen, um die Punktnotation am Objekt einzuleiten
  3. Und dann die Methode am Objekt aufrufen.

Diese Methode verlangt dann noch einen Parameter.
Also übergibst du den Vergleichswert.
Und Fertig.

Und so könnte dies dann aussehen:

  • frucht1.equals("Apfel");– vergleicht das Objekt für Frucht1 mit dem Textwert Apfel
  • frucht1.equals("Birne");-vergleicht den Textwert aus Frucht1 mit dem Textwert Birne
  • frucht2.equals("Pfirsich");-vergleicht den Textwert aus Frucht2 mit dem Textwert Pfirsich
  • frucht1.equals(frucht2);-vergleicht die Textwerte für Frucht1 und Frucht2 miteinander

In einer if else Abfrage könnte dies dann so aussehen:
Es wird geprüft, ob Frucht1 ein Apfel ist.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";// wird im Pool verwaltet
		String frucht2 = "Apfel";// wird im Pool verwaltet

		// Wird geprüft ob Frucht 1 ein Apfel ist
		if (frucht1.equals("Apfel")) {
			System.out.println("Es ist ein Apfel");
		} else {
			System.out.println("Es ist eine Birne");
		}
	}
}

Oder so:
Jetzt wird geprüft, ob Frucht1 eine Birne ist.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";// wird im Pool verwaltet
		String frucht2 = "Apfel";// wird im Pool verwaltet

		// Wird geprüft ob Frucht 1 ein Birne ist
		if (frucht1.equals("Birne")) {
			System.out.println("Es ist eine Birne");
		} else {
			System.out.println("Es ist ein Apfel");
		}
	}
}

Probiere jetzt einmal die Werte in deinem Code zu ändern.
Ändere den Wert für Frucht1 in Birne
Ändere die Abfrage und lass Frucht2 mit „Birne“ vergleichen.
Probiere etwas rum und werde sicherer im Umgang.

Und das letzte Beispiel.
In diesem Beispielcode wird geprüft, ob Frucht 1 und Frucht2 das selbe sind.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";// wird im Pool verwaltet
		String frucht2 = "Apfel";// wird im Pool verwaltet

		// Wird geprüft ob Frucht1 und Frucht2 gleich sind
		if (frucht1.equals(frucht2)) {
			System.out.println("Zwei gleiche Früchte");
		} else {
			System.out.println("unterschiedliche Früchte");
		}
	}
}

Auch hier kannst du ruhig etwas mit dem Code spielen.

Bei der equals-Vergleichsmethode spielt es keine Rolle, wo deine Strings liegen

Du kannst jetzt alle Strings vergleichen.
Es spielt also keine Rolle, ob diese mit Konstruktor oder ohne Konstruktor angelegt wurden.


public class StringVergleichen {

	public static void main(String[] args) {
		String frucht1 = "Apfel";// wird im Pool verwaltet
		String frucht3 = new String ("Birne");//wird auf dem Heap verwaltet

		// Wird geprüft ob Frucht1 und Frucht3 gleich sind
		if (frucht1.equals(frucht3)) {
			System.out.println("Zwei gleiche Früchte");
		} else {
			System.out.println("unterschiedliche Früchte");
		}
	}
}

Zusammenfassung:

  • Strings kannst du entweder über einen Konstruktoraufruf anlegen oder ohne.
  • In Java lassen sich Strings, welche ohne Konstruktor angelegt wurden mit dem Gleichheitsoperator vergleichen.
  • Dennoch werden auch hier nur Speicheradressen verglichen.
    Prinzipiell solltest du alle Java Strings mit der equals Methode vergleichen.

Ähnliche Beiträge

Java Objekte leben auf dem Heap

Java-Objekte-Heap

Java hat eine interne Speicherverwaltung. Eigentlich ist es nicht nur eine. Es sind mehrere.   Uns interessieren nur zwei. Methoden und lokale Variablen werden auf dem Stack verwaltet. Und die Speicherverwaltung für Java Objekte und den Instanzvariablen findet auf dem Heap statt.   Ja wieso braucht Java eigentlich zwei Speichersysteme?   Es ist ganz einfach. […]

Zwei smarte Möglichkeiten eine Java Zufallszahl zu erzeugen

Java Zufallszahl

Java Zufallszahl – Wieso? In der Java Programmierung benötigst du immer wieder einmal Zufallszahlen. Du möchtest deine Software mit Daten testen und dir keine Zahlen ausdenken. Du benötigst Stichproben, welche ein reales Verhalten simulieren. Du hast ein Spiel entworfen und die Akteure sollen mit zufälligen aber unterschiedlichen Größen, Rüstungsleveln usw. auftreten. Die Einsatzmöglichkeiten für Zufallszahlen […]

So kannst du in Java Und Verknüpfung anlegen und auswerten

Java Und

In Java stehen dir eine Menge Operatoren zur Verfügung. Einer dieser Operatoren ist der Und-Operator. Dies ist ein logischer Operator, da dieser sogenannte Wahrheitswerte mit einander verknüpft. Also…. Was erwartet dich in diesem Beitrag? Zuerst möchte ich dir die Aussagenlogik hinter dem Und-Operator zeigen. Also wann sind Aussagen wahr und wann sind diese falsch. Dann […]

Das Instanzieren von Java Klassen verhindern

Java Objekte Instanzieren verhindern

Die Instanzierung von Java Klassen verhindern. Was heißt das? Instanzen sind die Objekte einer Java Klasse. Und Instanzieren oder Instanzierung heißt nichts anderes, als Objekterstellung. Aber was soll das? Oder mal anders gefragt: Wieso sollte man verhindern, dass eine Java Klasse – Objekte erstellen kann? Schließlich sind doch Objekte der Sinn und Zweck jeder objektorientierten […]

So implementierst du Instanzmethoden in deine Java Klasse

Java Instanzmethoden

In einen der letzten Beiträge habe ich dir gezeigt, wie du eine Klasse anlegen kannst. Ich habe die Klasse „Mensch“ oder „Human“ angelegt und wir haben die erste Instanzvariable implementiert. Dein Code sollte jetzt so aussehen: public class Human { int size=156;//size in centimeter } In diesem Beitrag werde ich dir zeigen, wie du Java […]

Das Java Vererbung Konzept in einem Rollenspiel

Java ist eine objektorientierte Programmiersprache. Und das bedeutet nicht nur, dass du Objekte einer Java Klasse erzeugen kannst. Es bedeutet auch, dass Java Klassen von anderen Klassen erben können. Wieso das Ganze? Stell dir einmal ein Rollenspiel vor. Wie würdest du ein Rollenspiel entwerfen? In einem Rollenspiel gibt es magische Gegenstände. Zauberringe, Zauberstäbe, welche bei […]

Achte bei Java Methoden stets auf die Wertübergabe

Java Methoden Wertübergabe

Ich lege gleich los…. Schau dir diesen Code einmal an. Welche Zahl wird wohl auf der Bildschirmanzeige zurückgegeben? public class MethodenWertUebergabe { static int verdoppele (int i){ i=i*2; return i; } public static void main(String[] args) { int i = 2; verdoppele(i); System.out.println(i); } }

Der Java Datentyp boolean im Interview

Java boolean

Nein, ich bin nicht verrückt. Aber… Neulich traf ich zufällig den Java Datentyp boolean. 🙂 Er erklärte sich bereit, mir ein Interview zu geben. In diesem Interview geht es um die Werte, welcher dieser Wertetyp annehmen kann. Und in diesem Zusammenhang geht es auch um Logik. Also lassen wir uns doch die Logik vom direkten […]

Drei Möglichkeiten um Java Objekte zu zerstören

Java Objekte zerstören

Java Objekte leben genau solange, wie eine Referenzvariable auf sie zeigt. Wenn dieser Zeiger nicht mehr existiert, wird dieses Objekt aufgeben. Und wenn dieses Objekt erst einmal aufgegeben wurde, dann kommt der Garbage Collector und entsorgt dieses. Aber wie kannst du nun am Sinnvollsten Objekte aufgeben? Lass es uns herausfinden.