<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/migration83.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'de',
  ),
  'this' => 
  array (
    0 => 'migration83.new-features.php',
    1 => 'Neue Features',
    2 => 'Neue Features',
  ),
  'up' => 
  array (
    0 => 'migration83.php',
    1 => 'Migration von PHP 8.2.x auf PHP 8.3.x',
  ),
  'prev' => 
  array (
    0 => 'migration83.php',
    1 => 'Migration von PHP 8.2.x auf PHP 8.3.x',
  ),
  'next' => 
  array (
    0 => 'migration83.new-classes.php',
    1 => 'Neue Klassen und Schnittstellen',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'de',
    'path' => 'appendices/migration83/new-features.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="migration83.new-features" class="sect1">
 <h2 class="title">Neue Features</h2>

 <div class="sect2" id="migration83.new-features.core">
  <h3 class="title">PHP-Kern</h3>

  <div class="sect3" id="migration83.new-features.core.readonly-modifier-improvements">
   <h4 class="title">Ergänzungen beim Schreibschutz (Readonly)</h4>

   <p class="para">
    Anonyme Klassen können nun als readonly markiert werden.
   </p>

   <p class="para">
    Readonly-Eigenschaften können nun beim Klonen reinitialisiert werden.
    
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.typed-class-constants">
   <h4 class="title">Typisierte Klassenkonstanten</h4>

   <p class="para">
    Klassen-, Interface-, Trait- und Enum-Konstanten können nun typisiert
    deklariert werden.
    
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.closures-created-from-magic-methods">
   <h4 class="title">Von magischen Methoden erzeugte Closures</h4>

   <p class="para">
    Von magischen Methoden erzeugte Closures können nun benannte Argumente
    akzeptieren.
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.final-modifier-method-from-trait">
   <h4 class="title">Der Modifikator final bei einer Methode aus einem Trait</h4>

   <p class="para">
    Wenn eine Methode aus einem Trait verwendet wird, kann sie nun als final
    gekennzeichnet werden.
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.override-attribute">
   <h4 class="title">Das Attribut Override</h4>

   <p class="para">
    Das Attribut #[\Override] wurde hinzugefügt, damit überprüft wird, ob eine
    Methode in einer übergeordneten Klasse oder einer implementierten
    Schnittstelle existiert.
    
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.fetch-class-constant-dynamically-syntax">
   <h4 class="title">Syntax für das dynamische Abrufen von Klassenkonstanten</h4>

   <p class="para">
    Mit der Syntax <code class="code">C::{$name}</code> kann nun dynamisch auf
    Klassenkonstanten zugegriffen werden.
    
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.static-variable-initializers">
   <h4 class="title">Initialisierung statischer Variablen</h4>

   <p class="para">
    Für die Initialisierung statischer Variablen können nun beliebige Ausdrücke
    verwendet werden.
    
   </p>
  </div>

  <div class="sect3" id="migration83.new-features.core.fallback-value-syntax-for-php-ini">
   <h4 class="title">Syntax für Fallback-Werte bei ini-Variablen</h4>

   <p class="para">
    In der php.ini wird nun die Syntax für Fallback-/Standardwerte unterstützt.
    
    <div class="informalexample">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #FF8000">/*<br />Angenommen, die Datei /pfad/zu/user.ini enthält die folgenden Einstellungen:<br /><br />listen = localhost:${DRUPAL_FPM_PORT:-9000}<br />*/<br /><br /></span><span style="color: #0000BB">$user_ini </span><span style="color: #007700">= </span><span style="color: #0000BB">parse_ini_file</span><span style="color: #007700">(</span><span style="color: #DD0000">'/pfad/zu/user.ini'</span><span style="color: #007700">);<br />echo </span><span style="color: #0000BB">$user_ini</span><span style="color: #007700">[</span><span style="color: #DD0000">'listen'</span><span style="color: #007700">]; </span><span style="color: #FF8000">// localhost:9000</span></span></code></div>
     </div>

    </div>

   </p>
  </div>

 </div>

 <div class="sect2" id="migration83.new-features.cli">
  <h3 class="title">CLI</h3>

  <p class="para">
   Die Überprüfung der Syntax (Lint) kann nun bei mehreren Dateien
   gleichzeitig durchgeführt werden.
  </p>
 </div>

 <div class="sect2" id="migration83.new-features.dom">
  <h3 class="title">DOM</h3>

  <p class="para">
   Die Eigenschaften <span class="property"><a href="class.domelement.php#domelement.props.classname">DOMElement::$className</a></span> und
   <span class="property"><a href="class.domelement.php#domelement.props.id">DOMElement::$id</a></span> wurden hinzugefügt. Diese sind im
   Moment wegen der Einschränkungen der zugrundeliegenden libxml2 nicht
   binärsicher. Das bedeutet, dass die Werte der Eigenschaften an einem
   NUL-Byte abgeschnitten werden.
  </p>

  <p class="para">
   Die Eigenschaften <span class="property"><a href="class.domnode.php#domnode.props.isconnected">DOMNode::$isConnected</a></span> und
   <span class="property"><a href="class.domnamespacenode.php#domnamespacenode.props.isconnected">DOMNameSpaceNode::$isConnected</a></span> wurden hinzugefügt.
  </p>

  <p class="para">
   Die Eigenschaften <span class="property"><a href="class.domnode.php#domnode.props.parentelement">DOMNode::$parentElement</a></span> und
   <span class="property"><a href="class.domnamespacenode.php#domnamespacenode.props.parentelement">DOMNameSpaceNode::$parentElement</a></span> wurden hinzugefügt.
  </p>
 </div>

 <div class="sect2" id="migration83.new-features.ffi">
  <h3 class="title">FFI</h3>

  <p class="para">
   Es ist nun möglich, <span class="classname"><a href="class.ffi-cdata.php" class="classname">FFI\CData</a></span> anderen FFI\CData
   zuzuweisen. Das bedeutet, dass CData nun Strukturen und Feldern zugewiesen
   werden kann.
  </p>
 </div>

 <div class="sect2" id="migration83.new-features.opcache">
  <h3 class="title">Opcache</h3>

  <p class="para">
   <code class="code">opcache_get_status()[&#039;scripts&#039;][n][&#039;revalidate&#039;]</code> enthält nun
   einen Unix-Zeitstempel, der angibt, wann das Skript das nächste Mal
   revalidiert werden muss. Dies wird durch die INI-Direktive
   <a href="opcache.configuration.php#ini.opcache.revalidate-freq" class="link">opcache.revalidate_freq</a>
   festgelegt.
  </p>
 </div>

 <div class="sect2" id="migration83.new-features.posix">
  <h3 class="title">POSIX</h3>

  <p class="para">
   <span class="function"><a href="function.posix-getrlimit.php" class="function">posix_getrlimit()</a></span> akzeptiert nun einen optionalen
   <code class="parameter">$resource</code>-Parameter, um ein einzelnes Ressourcenlimit
   abrufen zu können.
  </p>

  <p class="para">
   <span class="function"><a href="function.posix-isatty.php" class="function">posix_isatty()</a></span> folgt nun der normalen Semantik der
   Parameterauswertung (ZPP) und gibt eine Typ-Warnung für Integer-Werte aus.
  </p>

  <p class="para">
   <span class="function"><a href="function.posix-ttyname.php" class="function">posix_ttyname()</a></span> folgt nun der normalen Semantik der
   Parameterauswertung (ZPP) und gibt eine Typ-Warnung für Integer-Werte aus.
   Darüber hinaus wird nun für Integer-Werte ungültiger Dateideskriptoren eine
   Wert-Warnung ausgegeben.
  </p>
 </div>

 <div class="sect2" id="migration83.new-features.streams">
  <h3 class="title">Streams</h3>

  <p class="para">
   Streams können nun die Benachrichtigung
   <strong><code><a href="stream.constants.php#constant.stream-notify-completed">STREAM_NOTIFY_COMPLETED</a></code></strong> senden. Dies war bisher nicht
   implementiert.
  </p>
 </div>

</div><?php manual_footer($setup); ?>