Zend_Config-TheoryOfOperation.xml 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.config.theory_of_operation">
  5. <title>動作原理</title>
  6. <para>
  7. <classname>Zend_Config</classname> のコンストラクタを通じて、
  8. 設定データに連想配列形式でアクセスできるようになります。
  9. 多次元の連想配列となる可能性もあり、
  10. これによって汎用的なデータから何かに固有のデータまで扱えるようになります。
  11. 具象アダプタクラスの機能は、
  12. どこかに保存されているデータを読み込んでこの連想配列形式を作成し、
  13. し、<classname>Zend_Config</classname> のコンストラクタに渡すことです。
  14. スクリプト内で直接配列を作成し、それを
  15. <classname>Zend_Config</classname> のコンストラクタに渡すことも可能です。
  16. この場合はアダプタクラスは使用しません。
  17. 場合によってはこのような方式のほうが適切なこともあるでしょう。
  18. </para>
  19. <para>
  20. 設定データ配列の値が、それぞれ <classname>Zend_Config</classname>
  21. オブジェクトのプロパティとなります。配列のキーがプロパティ名となります。
  22. 配列の値自身がまた配列であった場合、対応するプロパティの値は新しい
  23. <classname>Zend_Config</classname> オブジェクトとなります。この中に配列の内容が読み込まれます。
  24. この処理は再帰的に行われるので、
  25. 階層構造になっている設定データは任意のレベルでこの構造が繰り返されることになります。
  26. </para>
  27. <para>
  28. <classname>Zend_Config</classname> は内部で <emphasis>Countable</emphasis>
  29. インターフェイスおよび <emphasis>Iterator</emphasis>
  30. インターフェイスを実装しており、
  31. これを使用して設定データに容易にアクセスできるようになっています。
  32. つまり、<classname>Zend_Config</classname> オブジェクトに対して
  33. <ulink url="http://php.net/count"><methodname>count()</methodname></ulink>
  34. 関数や <ulink url="http://php.net/foreach"><emphasis>foreach</emphasis></ulink>
  35. などを使用できるということです。
  36. </para>
  37. <para>
  38. デフォルトでは、<classname>Zend_Config</classname>
  39. で利用できる設定データは読み込み専用です。代入
  40. (<command>$config->database->host = 'example.com';</command> など)
  41. を行おうとすると例外がスローされます。しかし、
  42. コンストラクタでこの振る舞いを変更し、データの変更を許可することも可能です。
  43. また、変更を許可した場合には、<classname>Zend_Config</classname>
  44. は値の設定の解除もサポートしています
  45. (<methodname>unset($config->database->host)</methodname> とします)。
  46. <methodname>readOnly()</methodname> メソッドを使用すると、
  47. 指定した <classname>Zend_Config</classname> オブジェクトの変更が許可されているかどうかを取得することができます。
  48. また <methodname>setReadOnly()</methodname> メソッドを使用すると、
  49. 変更を許可する設定だった <classname>Zend_Config</classname>
  50. オブジェクトに対してそれ以降の変更を禁じることができます。
  51. </para>
  52. <note>
  53. <para>
  54. メモリ上で変更したデータを何らかのメディアに保存しようとする際に、
  55. ちょっと戸惑うかもしれません。
  56. 作成したり変更したりした設定データをメディアに保存する機能は、今のところ
  57. <classname>Zend_Config</classname> の対象範囲外です。
  58. 設定データを作成・編集してメディアに保存するには、
  59. サードパーティからオープンソースのソリューションが提供されています。
  60. </para>
  61. </note>
  62. <para>
  63. <classname>Zend_Config</classname> クラスを継承したアダプタクラスが、
  64. それぞれの内容に応じて機能を拡張します。
  65. </para>
  66. <para>
  67. <classname>Zend_Config</classname> ファミリーのクラスを使用すると、
  68. 設定データをセクション単位でまとめることができます。
  69. <classname>Zend_Config</classname> オブジェクトの特定のセクションだけを読み込んだり、
  70. 複数のセクションを指定して読み込んだり、あるいは
  71. (何も指定しなければ) 全セクションを読み込んだりといったことが可能です。
  72. </para>
  73. <para>
  74. <classname>Zend_Config</classname> は単一継承モデルをサポートしており、
  75. 設定データの特定のセクションを別のセクションに継承させることができます。
  76. この機能が提供されている理由は、
  77. さまざまな目的のために設定データを二重管理する必要をなくすためです。
  78. 継承したセクションでは、親セクションから継承した値を上書きすることができます。
  79. <acronym>PHP</acronym> のクラス継承と同様に、あるセクションが親セクションを継承し、
  80. そのセクションがまた上位セクションを継承し、といったことが可能です。
  81. しかし多重継承 (例えば、セクション C がセクション A およびセクション B
  82. のふたつを直接継承するなど) はサポートされていません。
  83. </para>
  84. <para>
  85. ふたつの <classname>Zend_Config</classname> オブジェクトがある場合に、
  86. <methodname>merge()</methodname> 関数でそれをひとつにまとめることができます。
  87. たとえば、<varname>$config</varname> と <varname>$localConfig</varname>
  88. がある場合に <varname>$localConfig</varname> のデータを <varname>$config</varname>
  89. に統合するには <command>$config->merge($localConfig);</command> とします。
  90. <varname>$localConfig</varname> の中に <varname>$config</varname>
  91. と同名の項目がある場合は、もとの値は上書きされます。
  92. </para>
  93. <note>
  94. <para>
  95. <classname>Zend_Config</classname> オブジェクトをまとめる場合は、
  96. 変更を許可する設定で作成する必要があります。つまり、
  97. コンストラクタの 2 番目のパラメータに <constant>TRUE</constant> を渡します。
  98. まとめが完了した後で <methodname>setReadOnly()</methodname>
  99. メソッドを使用すると、それ以降の変更を禁じることができます。
  100. </para>
  101. </note>
  102. </sect1>
  103. <!--
  104. vim:se ts=4 sw=4 et:
  105. -->