<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/reserved.attributes.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'class.delayedtargetvalidation.php',
    1 => 'DelayedTargetValidation',
    2 => 'DelayedTargetValidation アトリビュート',
  ),
  'up' => 
  array (
    0 => 'reserved.attributes.php',
    1 => '定義済みのアトリビュート',
  ),
  'prev' => 
  array (
    0 => 'allowdynamicproperties.construct.php',
    1 => 'AllowDynamicProperties::__construct',
  ),
  'next' => 
  array (
    0 => 'class.deprecated.php',
    1 => 'Deprecated',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'language/predefined/attributes/delayedtargetvalidation.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="class.delayedtargetvalidation" class="reference">
 <h1 class="title">DelayedTargetValidation アトリビュート</h1>
 

 <div class="partintro"><p class="verinfo">(PHP 8 &gt;= 8.5.0)</p>

  <div class="section" id="delayedtargetvalidation.intro">
   <h2 class="title">はじめに</h2>
   <p class="simpara">
    このアトリビュートは、内部アトリビュートに対する適用対象の検証エラーを、
    コンパイル時から、Reflection API を通じてアトリビュートがインスタンス化される時点へと遅延させます。
   </p>
   <p class="simpara">
    宣言に適用すると、同じ適用対象における内部アトリビュートの不正な使用は、
    コンパイル時のエラーを引き起こしません。代わりに検証は先送りされ、
    <a href="reflectionattribute.newinstance.php" class="link">ReflectionAttribute::newInstance()</a>
    を通じてアトリビュートがインスタンス化される時点で実行されます。
   </p>
   <p class="simpara">
    これは主に前方互換性を意図したものであり、
    将来の PHP バージョンで有効な適用対象が追加されうるアトリビュートを使うコードを、
    古いバージョンで壊さずに済むようにします。
   </p>
  </div>

  <div class="section" id="delayedtargetvalidation.synopsis">
   <h2 class="title">クラス概要</h2>

   <div class="classsynopsis"><div class="classsynopsisinfo">
    
     <span class="attribute"><a href="class.attribute.php">#[\Attribute]</a> </span><br>
     <span class="modifier">final</span>
     <span class="modifier">class</span> <strong class="classname"><strong class="classname">DelayedTargetValidation</strong></strong>
     {</div>
   }</div>

  </div>

  <div class="section" id="delayedtargetvalidation.examples">
   <h2 class="title">例</h2>

   <div class="example" id="example-1">
    <p><strong>例1 不正な適用対象の検証を遅延させる</strong></p>
    <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">class </span><span style="color: #0000BB">Base </span><span style="color: #007700">{<br />    protected function </span><span style="color: #0000BB">foo</span><span style="color: #007700">(): </span><span style="color: #0000BB">void </span><span style="color: #007700">{}<br />}<br /><br />class </span><span style="color: #0000BB">Child </span><span style="color: #007700">extends </span><span style="color: #0000BB">Base </span><span style="color: #007700">{<br /><br />    #[</span><span style="color: #0000BB">\DelayedTargetValidation</span><span style="color: #007700">]<br />    #[</span><span style="color: #0000BB">\Override</span><span style="color: #007700">]<br />    public const </span><span style="color: #0000BB">NAME </span><span style="color: #007700">= </span><span style="color: #DD0000">'child'</span><span style="color: #007700">;<br /><br />    #[</span><span style="color: #0000BB">\Override</span><span style="color: #007700">]<br />    protected function </span><span style="color: #0000BB">foo</span><span style="color: #007700">(): </span><span style="color: #0000BB">void </span><span style="color: #007700">{}<br />}</span></span></code></div></div>


    <div class="example-contents"><p>
     <span class="classname"><a href="class.override.php" class="classname">Override</a></span> がクラス定数に対して使えない PHP バージョンであっても、
     これはコンパイル時のエラーを発生させません。
    </p></div>
   </div>

   <div class="example" id="example-2">
    <p><strong>例2 検証はリフレクション時に行われる</strong></p>
    <div class="example-contents"><div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />$reflection </span><span style="color: #007700">= new </span><span style="color: #0000BB">ReflectionClassConstant</span><span style="color: #007700">(</span><span style="color: #0000BB">Child</span><span style="color: #007700">::class, </span><span style="color: #DD0000">'NAME'</span><span style="color: #007700">);<br /><br />foreach (</span><span style="color: #0000BB">$reflection</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">getAttributes</span><span style="color: #007700">() as </span><span style="color: #0000BB">$attribute</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">$attribute</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">newInstance</span><span style="color: #007700">(); </span><span style="color: #FF8000">// 不正な場合はスローされる可能性がある<br /></span><span style="color: #007700">}</span></span></code></div></div>


    <div class="example-contents"><p>
     同じ適用対象に適用されたアトリビュート（DelayedTargetValidation 自身を除く）が、
     <a href="reflectionattribute.newinstance.php" class="link">ReflectionAttribute::newInstance()</a>
     を使ってリフレクション経由でインスタンス化されると、
     適用対象の検証が実行され、サポートされていない適用対象でアトリビュートが使われていれば
     例外がスローされる可能性があります。
    </p></div>
   </div>

  </div>

  <div class="section" id="delayedtargetvalidation.notes">
   <h2 class="title">注意</h2>
   <p class="simpara">
    このアトリビュートは、内部アトリビュートの適用対象の検証にのみ影響します。
   </p>
   <p class="simpara">
    これらのアトリビュートが実行する機能的な検証を抑制するわけではありません。
    たとえば <span class="classname"><a href="class.override.php" class="classname">Override</a></span> は、
    メソッドが実際には親のメソッドをオーバーライドしていない場合に、引き続きエラーを発生させます。
   </p>
  </div>

  <div class="section" id="delayedtargetvalidation.seealso">
   <h2 class="title">参考</h2>
   <ul class="simplelist">
    <li><a href="language.attributes.php" class="link">アトリビュートの概要</a></li>
    <li><a href="class.override.php" class="link">Override</a></li>
   </ul>
  </div>

 </div>

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