<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/language.namespaces.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'language.namespaces.basics.php',
    1 => 'Основы',
    2 => 'Основы пространств имён',
  ),
  'up' => 
  array (
    0 => 'language.namespaces.php',
    1 => 'Пространства имён',
  ),
  'prev' => 
  array (
    0 => 'language.namespaces.definitionmultiple.php',
    1 => 'Несколько пространств имён в одном файле',
  ),
  'next' => 
  array (
    0 => 'language.namespaces.dynamic.php',
    1 => 'Пространства имён и динамические особенности языка',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'language/namespaces.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="language.namespaces.basics" class="sect1">
  <h2 class="title">Основы пространств имён</h2>
  
  <p class="verinfo">(PHP 5 &gt;= 5.3.0, PHP 7, PHP 8)</p>
  <p class="para">
   Прежде чем обсуждать работу с пространствами имён, важно понять, как PHP узнаёт,
   какие элементы из пространства имён запрашиваются в коде. Можно провести
   аналогию между пространствами имён PHP и файловой системой. Есть три способа обратиться
   к файлу в файловой системе:
   <ol type="1">
    <li class="listitem">
     <span class="simpara">
      Относительное имя файла наподобие <code class="literal">foo.txt</code> разрешится
      в <code class="literal">currentdirectory/foo.txt</code>, где <code class="literal">currentdirectory</code> — текущая
      директория, в которой мы находимся. Тогда, если текущая директория —
      <code class="literal">/home/foo</code>, то имя преобразуется в <code class="literal">/home/foo/foo.txt</code>.
     </span>
    </li>
    <li class="listitem">
     <span class="simpara">
      Относительное имя пути наподобие <code class="literal">subdirectory/foo.txt</code> разрешится
      в <code class="literal">currentdirectory/subdirectory/foo.txt</code>.
     </span>
    </li>
    <li class="listitem">
     <span class="simpara">
      Абсолютное имя пути наподобие <code class="literal">/main/foo.txt</code> останется
      таким же: <code class="literal">/main/foo.txt</code>.
     </span>
    </li>
   </ol>
   Тот же принцип сохранится при разрешении элементов из пространств имён PHP.
   Название класса, например, указывают тремя способами:
   <ol type="1">
    <li class="listitem">
     <span class="simpara">
      Неполное имя, или название класса без префикса, наподобие
      <code class="literal">$a = new foo();</code>
      или <code class="literal">foo::staticmethod();</code>. В текущем пространстве имён
      <code class="literal">currentnamespace</code> такое название разрешится
      в <code class="literal">currentnamespace\foo</code>. В коде в глобальном
      пространстве имён название останется прежним: <code class="literal">foo</code>.
     </span>
     <span class="simpara">
      Предостережение: неполные названия функций и констант разрешаются
      в глобальные функции и константы, если их не определили в текущем пространстве имён.
      Подробнее об этом рассказывает раздел
      «<a href="language.namespaces.fallback.php" class="link">Пространства имён: возврат к глобальному пространству для функций и констант</a>».
     </span>
    </li>
    <li class="listitem">
     <span class="simpara">
      Полное имя, или название класса с префиксами наподобие
      <code class="literal">$a = new subnamespace\foo();</code>
      или <code class="literal">subnamespace\foo::staticmethod();</code>. В текущем пространстве имён
      <code class="literal">currentnamespace</code> такое название разрешится
      в <code class="literal">currentnamespace\subnamespace\foo</code>. В коде в глобальном
      пространстве имён название разрешится в <code class="literal">subnamespace\foo</code>.
     </span>
    </li>
    <li class="listitem">
     <span class="simpara">
      Абсолютное имя, или название с префиксом в начале,
      который указывает на глобальное пространство имён наподобие
      <code class="literal">$a = new \currentnamespace\foo();</code>
      или <code class="literal">\currentnamespace\foo::staticmethod();</code>. Такое название разрешается
      в буквальное, — которое указали в коде: <code class="literal">currentnamespace\foo</code>.
     </span>
    </li>
   </ol>
  </p>
  <p class="para">
   Вот пример трёх видов синтаксиса в реальном коде:
   <div class="informalexample">
    <p class="simpara">file1.php</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">namespace </span><span style="color: #0000BB">Foo\Bar\subnamespace</span><span style="color: #007700">;<br /><br />const </span><span style="color: #0000BB">FOO </span><span style="color: #007700">= </span><span style="color: #0000BB">1</span><span style="color: #007700">;<br /><br />function </span><span style="color: #0000BB">foo</span><span style="color: #007700">() {}<br /><br />class </span><span style="color: #0000BB">foo<br /></span><span style="color: #007700">{<br />    static function </span><span style="color: #0000BB">staticmethod</span><span style="color: #007700">() {}<br />}</span></span></code></div>
    </div>

    <p class="simpara">file2.php</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">namespace </span><span style="color: #0000BB">Foo\Bar</span><span style="color: #007700">;<br /><br />include </span><span style="color: #DD0000">'file1.php'</span><span style="color: #007700">;<br /><br />const </span><span style="color: #0000BB">FOO </span><span style="color: #007700">= </span><span style="color: #0000BB">2</span><span style="color: #007700">;<br />function </span><span style="color: #0000BB">foo</span><span style="color: #007700">() {}<br /><br />class </span><span style="color: #0000BB">foo<br /></span><span style="color: #007700">{<br />    static function </span><span style="color: #0000BB">staticmethod</span><span style="color: #007700">() {}<br />}<br /><br /></span><span style="color: #FF8000">/* Неполные имена */<br /></span><span style="color: #0000BB">foo</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в функцию Foo\Bar\foo<br /></span><span style="color: #0000BB">foo</span><span style="color: #007700">::</span><span style="color: #0000BB">staticmethod</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в метод staticmethod класса Foo\Bar\foo<br /></span><span style="color: #007700">echo </span><span style="color: #0000BB">FOO</span><span style="color: #007700">; </span><span style="color: #FF8000">// Разрешается в константу Foo\Bar\FOO<br /><br />/* Полные имена */<br /></span><span style="color: #0000BB">subnamespace\foo</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в функцию Foo\Bar\subnamespace\foo<br /></span><span style="color: #0000BB">subnamespace\foo</span><span style="color: #007700">::</span><span style="color: #0000BB">staticmethod</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в метод staticmethod класса Foo\Bar\subnamespace\foo<br /></span><span style="color: #007700">echo </span><span style="color: #0000BB">subnamespace\FOO</span><span style="color: #007700">; </span><span style="color: #FF8000">// Разрешается в константу Foo\Bar\subnamespace\FOO<br /><br />/* Абсолютные имена */<br /></span><span style="color: #0000BB">\Foo\Bar\foo</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в функцию Foo\Bar\foo<br /></span><span style="color: #0000BB">\Foo\Bar\foo</span><span style="color: #007700">::</span><span style="color: #0000BB">staticmethod</span><span style="color: #007700">(); </span><span style="color: #FF8000">// Разрешается в метод staticmethod класса Foo\Bar\foo<br /></span><span style="color: #007700">echo </span><span style="color: #0000BB">\Foo\Bar\FOO</span><span style="color: #007700">; </span><span style="color: #FF8000">// Разрешается в константу Foo\Bar\FOO</span></span></code></div>
     </div>

    </div>
   </p>
   <p class="para">
    Обратите внимание, что для доступа к глобальным
    классам, функциям или константам разрешается указывать абсолютное имя, например,
    <span class="function"><a href="function.strlen.php" class="function">\strlen()</a></span>, <span class="classname"><a href="class.exception.php" class="classname">\Exception</a></span>
    или \<strong><code><a href="info.constants.php#constant.ini-all">INI_ALL</a></code></strong>.
    <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">namespace </span><span style="color: #0000BB">Foo</span><span style="color: #007700">;<br /><br />function </span><span style="color: #0000BB">strlen</span><span style="color: #007700">() {}<br />const </span><span style="color: #0000BB">INI_ALL </span><span style="color: #007700">= </span><span style="color: #0000BB">3</span><span style="color: #007700">;<br />class </span><span style="color: #0000BB">Exception </span><span style="color: #007700">{}<br /><br /></span><span style="color: #0000BB">$a </span><span style="color: #007700">= </span><span style="color: #0000BB">\strlen</span><span style="color: #007700">(</span><span style="color: #DD0000">'hi'</span><span style="color: #007700">); </span><span style="color: #FF8000">// Вызывает глобальную функцию strlen<br /></span><span style="color: #0000BB">$b </span><span style="color: #007700">= </span><span style="color: #0000BB">\INI_ALL</span><span style="color: #007700">; </span><span style="color: #FF8000">// Получает доступ к глобальной константе INI_ALL<br /></span><span style="color: #0000BB">$c </span><span style="color: #007700">= new </span><span style="color: #0000BB">\Exception</span><span style="color: #007700">(</span><span style="color: #DD0000">'error'</span><span style="color: #007700">); </span><span style="color: #FF8000">// Создаёт экземпляр глобального класса Exception</span></span></code></div>
     </div>

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