<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.oop5.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'it',
  ),
  'this' => 
  array (
    0 => 'language.oop5.autoload.php',
    1 => 'Caricamento automatico delle classi',
    2 => 'Caricamento automatico delle classi',
  ),
  'up' => 
  array (
    0 => 'language.oop5.php',
    1 => 'Classi e Oggetti',
  ),
  'prev' => 
  array (
    0 => 'language.oop5.constants.php',
    1 => 'Costanti di classe',
  ),
  'next' => 
  array (
    0 => 'language.oop5.decon.php',
    1 => 'Constructors and Destructors',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'it',
    'path' => 'language/oop5/autoload.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.oop5.autoload" class="sect1">
  <h2 class="title">Caricamento automatico delle classi</h2>
  <p class="para">
   Molti sviluppatori che producono applicazioni orientate agli oggetti creano
   un file sorgente PHP per ogni classe definita. Uno dei più grossi inconvenienti
   di questo approccio è la necessità di mantenere una lunga lista di
   inclusioni all&#039;inizio di ogni script (un&#039;inclusione per ogni classe).
  </p>
  <p class="para">
   In PHP 5, ciò non è più necessario, in quanto è possibile definire una funzione
   <span class="function"><a href="function.autoload.php" class="function">__autoload()</a></span> che viene automaticamente
   invocata in caso si stia cercando di usare una classe/interfaccia che non sia stata
   ancora definita. Chiamando questa funzione, il motore di scripting ha una ultima
   possibilità di caricare la classe prima che PHP termini l&#039;esecuzione con un errore.
  </p>
  <div class="tip"><strong class="tip">Suggerimento</strong>
   <p class="para">
    La funzione <span class="function"><a href="function.spl-autoload-register.php" class="function">spl_autoload_register()</a></span> fornisce una alternative più flessibile
    per l&#039;autocaricamento delle classi. Per questa ragione, usare 
    la funzione <span class="function"><a href="function.autoload.php" class="function">__autoload()</a></span> è sconsigliato dato che in futuro potrà essere 
    rimossa o diventare deprecata.
   </p>
  </div>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Prima di 5.3.0, le eccezioni sollevate dalla funzione __autoload non potevano essere
    intercettate nel blocco <a href="language.exceptions.php" class="link">catch</a> e
    avrebbero portato ad un errore fatale. Da 5.3.0+ le eccezioni sollevate nella
    funzione __autoload possono essere intercettate nel blocco <a href="language.exceptions.php" class="link">
    catch</a>, con la sola precisazione che se si sta sollevando un&#039;eccezione definita dall&#039;utente
    la classe in cui l&#039;eccezione viene definita deve essere disponibile. La funzione __autoload può
    essere usata ricorsivamente per caricare la classe dell&#039;eccezione personalizzata.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    La funzionalità di autocaricamento non è disponibile se si sta usando PHP nella
    <a href="features.commandline.php" class="link">modalità interattiva</a> di CLI.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Nota</strong>: 
   <p class="para">
    Se il nome di classe è usato ad esempio in <span class="function"><a href="function.call-user-func.php" class="function">call_user_func()</a></span> esso
    può contenere alcuni caratteri pericolosi come <code class="literal">../</code>.
    Si raccomanda di non usare direttamente valori inputati dall&#039;utente in tali funzioni, o quanto meno di
    verificare l&#039;input <span class="function"><a href="function.autoload.php" class="function">__autoload()</a></span>.
   </p>
  </p></blockquote>
  <p class="para">
   <div class="example" id="example-1">
    <p><strong>Example #1 Esempio di autocaricamento</strong></p>
    <div class="example-contents"><p>
     Questo esempio cerca di caricare le classi <code class="literal">MyClass1</code>
     e <code class="literal">MyClass2</code> rispettivamente dai file <var class="filename">MyClass1.php</var>
     e <var class="filename">MyClass2.php</var>.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">__autoload</span><span style="color: #007700">(</span><span style="color: #0000BB">$class_name</span><span style="color: #007700">) {<br />    include </span><span style="color: #0000BB">$class_name </span><span style="color: #007700">. </span><span style="color: #DD0000">'.php'</span><span style="color: #007700">;<br />}<br /><br /></span><span style="color: #0000BB">$obj  </span><span style="color: #007700">= new </span><span style="color: #0000BB">MyClass1</span><span style="color: #007700">();<br /></span><span style="color: #0000BB">$obj2 </span><span style="color: #007700">= new </span><span style="color: #0000BB">MyClass2</span><span style="color: #007700">(); <br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
   <div class="example" id="example-2">
    <p><strong>Example #2 Altro esempio di autocaricamento</strong></p>
    <div class="example-contents"><p>
     Questo esempio tenta di caricare l&#039;interfaccia <code class="literal">ITest</code>.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">function </span><span style="color: #0000BB">__autoload</span><span style="color: #007700">(</span><span style="color: #0000BB">$name</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$name</span><span style="color: #007700">);<br />}<br /><br />class </span><span style="color: #0000BB">Foo </span><span style="color: #007700">implements </span><span style="color: #0000BB">ITest </span><span style="color: #007700">{<br />}<br /><br /></span><span style="color: #FF8000">/*<br />string(5) "ITest"<br /><br />Fatal error: Interface 'ITest' not found in ...<br />*/<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
   <div class="example" id="example-3">
    <p><strong>Example #3 Autocaricamento con gestione delle eccezioni per 5.3.0+</strong></p>
    <div class="example-contents"><p>
     Questo esempio solleva un&#039;eccezione e dimostra come intercettarla con il blocco try/catch.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">__autoload</span><span style="color: #007700">(</span><span style="color: #0000BB">$name</span><span style="color: #007700">) {<br />    echo </span><span style="color: #DD0000">"Si vuole caricare </span><span style="color: #0000BB">$name</span><span style="color: #DD0000">.\n"</span><span style="color: #007700">;<br />    throw new </span><span style="color: #0000BB">Exception</span><span style="color: #007700">(</span><span style="color: #DD0000">"Impossibile caricare </span><span style="color: #0000BB">$name</span><span style="color: #DD0000">."</span><span style="color: #007700">);<br />}<br /><br />try {<br />    </span><span style="color: #0000BB">$obj </span><span style="color: #007700">= new </span><span style="color: #0000BB">NonLoadableClass</span><span style="color: #007700">();<br />} catch (</span><span style="color: #0000BB">Exception $e</span><span style="color: #007700">) {<br />    echo </span><span style="color: #0000BB">$e</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getMessage</span><span style="color: #007700">(), </span><span style="color: #DD0000">"\n"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>Il precedente esempio visualizzerà:</p></div>
    <div class="example-contents screen">
<div class="cdata"><pre>
Si vuole caricare NonLoadableClass.
Impossibile caricare NonLoadableClass.
</pre></div>
    </div>
   </div>
   <div class="example" id="example-4">
    <p><strong>Example #4 Autocaricamento con gestione delle eccezioni per 5.3.0+ - Classe dell&#039;eccezione personalizzata mancante</strong></p>
    <div class="example-contents"><p>
     Questo esempio solleva un&#039;eccezione per una eccezione personalizzata non caricabile.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">function </span><span style="color: #0000BB">__autoload</span><span style="color: #007700">(</span><span style="color: #0000BB">$name</span><span style="color: #007700">) {<br />    echo </span><span style="color: #DD0000">"Si vuole caricare </span><span style="color: #0000BB">$name</span><span style="color: #DD0000">.\n"</span><span style="color: #007700">;<br />    throw new </span><span style="color: #0000BB">MissingException</span><span style="color: #007700">(</span><span style="color: #DD0000">"Impossibile </span><span style="color: #0000BB">$name</span><span style="color: #DD0000">."</span><span style="color: #007700">);<br />}<br /><br />try {<br />    </span><span style="color: #0000BB">$obj </span><span style="color: #007700">= new </span><span style="color: #0000BB">NonLoadableClass</span><span style="color: #007700">();<br />} catch (</span><span style="color: #0000BB">Exception $e</span><span style="color: #007700">) {<br />    echo </span><span style="color: #0000BB">$e</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getMessage</span><span style="color: #007700">(), </span><span style="color: #DD0000">"\n"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>Il precedente esempio visualizzerà:</p></div>
    <div class="example-contents screen">
<div class="cdata"><pre>
Si vuole caricare NonLoadableClass.
Si vuole caricare MissingException.

Fatal error: Class &#039;MissingException&#039; not found in testMissingException.php on line 4
</pre></div>
    </div>
   </div>
  </p>

  <div class="simplesect">
   <h3 class="title">Vedere anche:</h3>
   <p class="para">
    <ul class="simplelist">
     <li><span class="function"><a href="function.unserialize.php" class="function">unserialize()</a></span></li>
     <li><a href="var.configuration.php#unserialize-callback-func" class="link">unserialize_callback_func</a></li>
     <li><span class="function"><a href="function.spl-autoload.php" class="function">spl_autoload()</a></span></li>
     <li><span class="function"><a href="function.spl-autoload-register.php" class="function">spl_autoload_register()</a></span></li>
    </ul>
   </p>
  </div>

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