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

So lassen sich Java Strings in char zerlegen

Java Strings zerlegen char

Java Strings sind Zeichenketten. Und diese Zeichenketten lassen sich aufsplitten und in ihre Einzelteile zerlegen. Ich möchte dir in diesem Beitrag Möglichkeiten vorstellen, wie du Strings in Character-Datentypen zerlegen, extrahieren und die Einzelteile in Arrays speichern kannst.

So kannst du gelöschte Java Projekte oder Dateien in Eclipse wieder herstellen

Wahrscheinlich passiert es jedem einmal, dass man versehentlich Dateien löscht. Und dann? Die Wut ist riesig, weil man ja alles nochmal schreiben muss. In Eclipse hast du die Möglichkeit sämtliche Dateien wieder herzustellen. In diesem Beitrag möchte ich dir demonstrieren, wie du gelöschte Java Klassen, Dateien, Projekte oder Packages wieder herstellen kannst.

So verwendest du in Java try und catch Blöcke

Java try und catch

Ich bereue lieber die Dinge, die ich getan habe – als die Dinge, welche ich gar nicht erst versucht habe. Ja ich würde mich als den typischen „try-and-error-Menschen“ bezeichnen. Was ich will, probiere ich einfach aus und schaue dann erst was passiert. So etwas wie Pläne kenne ich eigentlich nicht. Und wenn ich mal einen […]

Ohne Abstraktion ergibt Java Polymorphie wenig Sinn

Java Polymorphie Abstraktionsprinzip

Kennst du den Film Matrix? Denn kennst du vielleicht auch die Botschaft, welche der Protagonist am Anfang des Filmes erhält. „Folge dem weißen Kaninchen.“ Und so ähnlich ist es jetzt auch in diesem Beitrag. „Wir dringen immer tiefer in den Kaninchenbau ein.“ 🙂 Ganz so wie im Film wird es nicht. Aber bevor wir mit […]

3 Möglichkeiten – Java Strings verketten und zusammenfügen

Java Strings verketten

Kennst du dieses Relikt längst vergangener Tage? Ein Brief. Ja früher einmal war es üblich, Briefe zu schreiben. Lange bevor es Smartphones oder Email gab. Man stelle sich einmal vor…. Die Leute mussten sich hinsetzen mit einem Blatt und einem Stift – und richtig schreiben. Nein nicht tippen – schreiben. 🙂 Grausame Welt, oder? Aber […]

10 ganz nützlichen Feature der Klasse Java Math

In diesem Beitrag geht es um eine spezielle Java Klasse. Die Klasse nennt sich Java Math. Diese ist in der Standardbibliothek von Java enthalten. Warum solltest du diese Klasse kennen? Die Math Klasse bietet dir einen Menge Methoden an, welche zur Berechnung von mathematischen Gleichungen ganz hilfreich sind. Aber auch für Nichtmathematiker ist etwas dabei. […]

8 Java Datentypen, die du kennen solltest

Java Datentypen

Java Datentypen Ich gebe zu, ich hasse dieses Thema. Denn es ist eigentlich nichts weiter als graue Theorie. Dennoch müssen wir dieses Thema behandeln. Um schnell in das Thema zu kommen, stelle ich dir eine Übersicht aller primitiven Datentypen zur Verfügung. Wieso primitive? Es gibt außer den primitiven Datentypen, noch Referenztypen. Und diese Referenztypen sind […]

Java Polymorphie – besserer Code und mehr Möglichkeiten

Java Polymorphie Vorteile

Polymorphie ist das Herzstück jeder objektorientierten Sprache. Nicht nur in Java – auch in Python, Javascript und in anderen Sprachen. Aber was bedeutet Polymorphie eigentlich? Polymorphie oder auch Polymorphismus genannt, kommt aus dem Griechischen. Es bedeutet Vielgestaltigkeit. Etwas freier übersetzt, kannst du es auch als Facettenreichtum bezeichnen. Im Grunde genommen zielt die ganze Java Vererbung […]

Von Java Klassen zum Java Programm – Der Programmstart

Java Klassen ausführen

In den letzten Beiträgen hast du gelernt, wie Java Klassen erstellt werden und aufgebaut sind. In diesem Beitrag geht es um den Programmstart. Ich will dir zeigen, was nötig ist, dass du ein Java Programm ausführen kannst. Und ich zeige dir außerdem, wie du eine Startklasse in einem x-beliebigen Javaprogramm anlegst. Wie auch schon zuvor, […]