<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://mletkin.net/index.php?action=history&amp;feed=atom&amp;title=Java_17%3A_instanceof</id>
	<title>Java 17: instanceof - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://mletkin.net/index.php?action=history&amp;feed=atom&amp;title=Java_17%3A_instanceof"/>
	<link rel="alternate" type="text/html" href="https://mletkin.net/index.php?title=Java_17:_instanceof&amp;action=history"/>
	<updated>2026-05-13T21:17:45Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in MimiPedia</subtitle>
	<generator>MediaWiki 1.39.4</generator>
	<entry>
		<id>https://mletkin.net/index.php?title=Java_17:_instanceof&amp;diff=164&amp;oldid=prev</id>
		<title>Ullrich: Die Seite wurde neu angelegt: „category:Java Die Diskussion ob {{java|instanceof}} gut oder schlecht, ob Downcasting un-objektorientiert ist oder nicht, soll ein anderesmal geführt werden, hier soll es nur darum gehen, was Java 17 neues für den umstrittensten aller  Java-Operatoren bringt.  {{java|instanceof}} wird meist zusammen mit einem Downcast verwendet um zu prüfen, ob dieser überhaupt möglich ist. zur Erinnerung: Downcasting heißt, ein Objekt auf eine Subclass der Klas…“</title>
		<link rel="alternate" type="text/html" href="https://mletkin.net/index.php?title=Java_17:_instanceof&amp;diff=164&amp;oldid=prev"/>
		<updated>2023-10-21T14:19:40Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „&lt;a href=&quot;/index.php?title=Kategorie:Java&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Kategorie:Java (Seite nicht vorhanden)&quot;&gt;category:Java&lt;/a&gt; Die Diskussion ob {{java|instanceof}} gut oder schlecht, ob Downcasting un-objektorientiert ist oder nicht, soll ein anderesmal geführt werden, hier soll es nur darum gehen, was Java 17 neues für den umstrittensten aller  Java-Operatoren bringt.  {{java|instanceof}} wird meist zusammen mit einem Downcast verwendet um zu prüfen, ob dieser überhaupt möglich ist. zur Erinnerung: Downcasting heißt, ein Objekt auf eine Subclass der Klas…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[category:Java]]&lt;br /&gt;
Die Diskussion ob {{java|instanceof}} gut oder schlecht, ob Downcasting un-objektorientiert ist oder nicht,&lt;br /&gt;
soll ein anderesmal geführt werden, hier soll es nur darum gehen, was Java 17 neues für den umstrittensten aller &lt;br /&gt;
Java-Operatoren bringt.&lt;br /&gt;
&lt;br /&gt;
{{java|instanceof}} wird meist zusammen mit einem Downcast verwendet um zu prüfen, ob dieser überhaupt möglich ist.&lt;br /&gt;
zur Erinnerung: Downcasting heißt, ein Objekt auf eine Subclass der Klasse zu casten unter der man es erhalten hat.&lt;br /&gt;
Am einfachsten sieht man das an einem Beispiel:&lt;br /&gt;
{{java|code=&lt;br /&gt;
 void foo(Object obj) {&lt;br /&gt;
    if (obj instanceof Integer) {&lt;br /&gt;
        Integer zahl = (Integer)obj;&lt;br /&gt;
        system.out.println(&amp;quot;Wert:&amp;quot; + zahl.intValue());&lt;br /&gt;
    }&lt;br /&gt;
 }&lt;br /&gt;
}}&lt;br /&gt;
Ohne den Downcast könnte man nicht auf die Methode {{java|intValue}} zugreifen und ohne die Prüfung mit&lt;br /&gt;
{{java| instanceof}} liefe man gefahr eine {{java|ClassCastException}} zu werfen.&lt;br /&gt;
&lt;br /&gt;
Java 17 erlaubt uns nun, die Prüfung und den Cast zusammenzufassen und dabei die Variable anzugeben:&lt;br /&gt;
{{java|code=&lt;br /&gt;
 void foo(Object obj) {&lt;br /&gt;
    if (obj instanceof Integer zahl) {&lt;br /&gt;
        system.out.println(&amp;quot;Wert:&amp;quot; + zahl.intValue());&lt;br /&gt;
    }&lt;br /&gt;
 }&lt;br /&gt;
}}&lt;br /&gt;
Nicht viel, spart nur eine Zeile -- aber immerhin eine Zeile weniger.&lt;br /&gt;
&lt;br /&gt;
Dieser etwas merkwürdige Scope (Bereich der Sichtbarkeit) der Variable ist uns seit Java 7 vom try...with resources her vertraut:&lt;br /&gt;
er erstreckt sich aus den runden Klammern der if-Bedingung hinaus über den nachfolgenden Block.&lt;br /&gt;
&lt;br /&gt;
Etwas bizarr wird&amp;#039;s allerdings hier:&lt;br /&gt;
{{java|code=&lt;br /&gt;
 void foo(Object obj) {&lt;br /&gt;
    if (! obj instanceof Integer zahl) {&lt;br /&gt;
        throw new RuntimeException();&lt;br /&gt;
    }&lt;br /&gt;
    system.out.println(&amp;quot;Wert:&amp;quot; + zahl.intValue());&lt;br /&gt;
 }&lt;br /&gt;
}}&lt;br /&gt;
Der Compiler erkennt, daß das Casting im if-Block keinen Sinn ergiebt und verzichtet auf die&lt;br /&gt;
Erzeugung der lokalen Variable. Dafür merkt er, daß das Cast &amp;#039;&amp;#039;nach&amp;#039;&amp;#039; dem if-Block möglich ist&lt;br /&gt;
und stellt sie dort auch zur Verfügung. Ob dieses Feature wirklich sinnvolle Anwendungen hat sei mal dahingestellt,&lt;br /&gt;
an das Konstrukt an sich muß man sich aber erstmal gewöhnen. Ohne IDE hat man da schlechte Karten den Überblick zu wahren.&lt;br /&gt;
&lt;br /&gt;
In der Java-Spec ist da auch von &amp;quot;Type Pattern Matching&amp;quot; die Rede. Ein Hinweis darauf, daß es sich hier nur um die Spitze eines&lt;br /&gt;
neuen Konzept-Eisbergs handelt. in Java 21 sieht man denn auch, wie das pattern matching das switch-Konstrukt so richtig aufzumischen vermag.&lt;br /&gt;
&lt;br /&gt;
Bis dahin nehmen wir aber auf jeden Fall die Ein-Zeilen-Ersparnis gerne mit.&lt;/div&gt;</summary>
		<author><name>Ullrich</name></author>
	</entry>
</feed>