<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/refs.fileprocess.process.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'book.parallel.php',
    1 => 'parallel',
    2 => 'parallel',
  ),
  'up' => 
  array (
    0 => 'refs.fileprocess.process.php',
    1 => 'Модули управления процессами программ',
  ),
  'prev' => 
  array (
    0 => 'function.system.php',
    1 => 'system',
  ),
  'next' => 
  array (
    0 => 'parallel.setup.php',
    1 => 'Установка',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/parallel/book.xml',
  ),
  'history' => 
  array (
  ),
  'extra_header_links' => 
  array (
    'rel' => 'alternate',
    'href' => '/manual/en/feeds/book.parallel.atom',
    'type' => 'application/atom+xml',
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="book.parallel" class="book">
 
 <h1 class="title">parallel</h1>
 

 <div id="intro.parallel" class="preface">
  <h1 class="title">Введение</h1>
  <p class="simpara">
   parallel - это модуль параллельного выполнения для PHP ≥ 7.2.0.
   Начиная с parallel 1.2.0, требуется PHP ≥ 8.0.0.
  </p>
  <p class="simpara">
   Краткое описание основных понятий параллельных процессов описано ниже, более подробную информацию можно найти в этом разделе руководства.
  </p>
  <div class="simplesect">
   <h3 class="title">Runtime</h3>
   <p class="simpara">
    <span class="classname"><a href="class.parallel-runtime.php" class="classname">parallel\Runtime</a></span> представляет поток интерпретатора PHP. <span class="classname"><a href="class.parallel-runtime.php" class="classname">parallel\Runtime</a></span> настроен с дополнительным файлом начальной загрузки, переданным в <span class="methodname"><a href="parallel-runtime.construct.php" class="methodname">parallel\Runtime::__construct()</a></span>, обычно это автозагрузчик
    или какая-либо другая процедура предварительной загрузки: файл начальной загрузки будет подключаться перед выполнением любой задачи.
   </p>
   <p class="simpara">
    После создания <span class="classname"><a href="class.parallel-runtime.php" class="classname">parallel\Runtime</a></span> остаётся доступным до тех пор, пока он не будет закрыт, уничтожен или уничтожен обычными правилами области видимости объектов PHP.
    <span class="methodname"><a href="parallel-runtime.run.php" class="methodname">parallel\Runtime::run()</a></span> позволяет программисту планировать задачи для параллельного выполнения.
    У <span class="classname"><a href="class.parallel-runtime.php" class="classname">parallel\Runtime</a></span> расписание FIFO, задачи будут выполняться в том порядке, в котором они запланированы.
   </p>
  </div>
  <div class="simplesect">
   <h3 class="title">Функциональный API</h3>
   <p class="simpara">
    parallel реализует функциональный API более высокого уровня поверх <span class="classname"><a href="class.parallel-runtime.php" class="classname">parallel\Runtime</a></span>, который обеспечивает единую точку входа функции для выполнения параллельного кода
    с автоматическим планированием: <span class="function"><a href="parallel.run.php" class="function">parallel\run()</a></span>.
   </p>
  </div>
  <div class="simplesect">
   <h3 class="title">Задача</h3>
   <p class="para">
    Задача - это просто замыкание (<span class="classname"><a href="class.closure.php" class="classname">Closure</a></span>), предназначенное для параллельного выполнения. <span class="classname"><a href="class.closure.php" class="classname">Closure</a></span> может содержать практически любую инструкцию, включая вложенные замыкания.
    Однако есть некоторые инструкции, которые запрещены в задачах:
    <ul class="itemizedlist">
     <li class="listitem">
     <span class="simpara">yield</span>
     </li>
     <li class="listitem">
     <span class="simpara">use by-reference</span>
     </li>
     <li class="listitem">
     <span class="simpara">declare class</span>
     </li>
     <li class="listitem">
     <span class="simpara">declare named function</span>
     </li>
    </ul>
   </p>
   <blockquote class="note"><p><strong class="note">Замечание</strong>: 
    <span class="simpara">
     Вложенные замыкания могут содержать &quot;yield&quot; или &quot;use by-reference&quot;, но не должны содержать объявления классов или именованных функций.
    </span>
   </p></blockquote>
   <blockquote class="note"><p><strong class="note">Замечание</strong>: 
    <span class="simpara">
     Никакие инструкции не запрещены в файлах, которые может включать задача.
    </span>
   </p></blockquote>
  </div>
  <div class="simplesect">
   <h3 class="title">Фьючерс</h3>
   <p class="simpara">
    <span class="classname"><a href="class.parallel-future.php" class="classname">parallel\Future</a></span> используется для доступа к возвращаемому значению из задачи и предоставляет API для отмены задачи.
   </p>
  </div>
  <div class="simplesect">
   <h3 class="title">Канал</h3>
   <p class="simpara">
    Задачу можно запланировать с аргументами, использовать переменные лексической области видимости (по значению) и вернуть значение (с помощью <span class="classname"><a href="class.parallel-future.php" class="classname">parallel\Future</a></span>), но это разрешает только однонаправленную связь:
    Это позволяет программисту отправлять данные и извлекать данные из задачи, но не допускают двунаправленную связь между задачами.
    API <span class="classname"><a href="class.parallel-channel.php" class="classname">parallel\Channel</a></span> обеспечивает двунаправленную связь между задачами, <span class="classname"><a href="class.parallel-channel.php" class="classname">parallel\Channel</a></span> - это соединение типа сокета между задачами, которое программист может использовать для отправки и получения данных.
   </p>
  </div>
  <div class="simplesect">
   <h3 class="title">События</h3>
   <p class="simpara">
    API <span class="classname"><a href="class.parallel-events.php" class="classname">parallel\Events</a></span> реализует собственный цикл событий (<span class="classname"><a href="class.traversable.php" class="classname">Traversable</a></span>) и метод <span class="methodname"><a href="parallel-events.poll.php" class="methodname">parallel\Events::poll()</a></span>.
    Это позволяет программисту работать с наборами каналов и/или фьючерсами.
    Программист просто добавляет каналы и фьючерсы в цикл событий, необязательно устанавливая вход для записи с помощью <span class="methodname"><a href="parallel-events.setinput.php" class="methodname">parallel\Events::setInput()</a></span>,
    и входит в foreach: parallel будет читать и записывать объекты по мере их превращения. Доступно с получением объектов <span class="classname"><a href="class.parallel-events-event.php" class="classname">parallel\Events\Event</a></span>,
    описывающих произошедшие операции.
   </p>
  </div>
   <div class="simplesect">
   <h3 class="title">Смотрите также</h3>
   <ul class="simplelist">
    <li><a href="philosophy.parallel.php" class="xref">Философия</a></li>
   </ul>
  </div>
 </div>

 





 





 





 





 





 





 





 





 





 






 





 

<ul class="chunklist chunklist_book"><li><a href="parallel.setup.php">Установка</a></li><li><a href="philosophy.parallel.php">Философия</a></li><li><a href="functional.parallel.php">Функциональный API</a><ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel.bootstrap.php">parallel\bootstrap</a> — Начальная загрузка</li><li><a href="parallel.run.php">parallel\run</a> — Выполнение</li></ul></li><li><a href="class.parallel-runtime.php">parallel\Runtime</a> — Класс parallel\Runtime<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-runtime.construct.php">parallel\Runtime::__construct</a> — Конструктор класса Runtime</li><li><a href="parallel-runtime.run.php">parallel\Runtime::run</a> — Выполнение</li><li><a href="parallel-runtime.close.php">parallel\Runtime::close</a> — Изящное соединение во время выполнения</li><li><a href="parallel-runtime.kill.php">parallel\Runtime::kill</a> — Соединение во время выполнения</li></ul></li><li><a href="class.parallel-future.php">parallel\Future</a> — Класс parallel\Future<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-future.cancel.php">parallel\Future::cancel</a> — Прекращение</li><li><a href="parallel-future.cancelled.php">parallel\Future::cancelled</a> — Определение состояния</li><li><a href="parallel-future.done.php">parallel\Future::done</a> — Определение состояния</li><li><a href="parallel-future.value.php">parallel\Future::value</a> — Разрешение</li></ul></li><li><a href="class.parallel-channel.php">parallel\Channel</a> — Класс parallel\Channel<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-channel.construct.php">parallel\Channel::__construct</a> — Конструктор класса Channel</li><li><a href="parallel-channel.make.php">parallel\Channel::make</a> — Доступ</li><li><a href="parallel-channel.open.php">parallel\Channel::open</a> — Доступ</li><li><a href="parallel-channel.recv.php">parallel\Channel::recv</a> — Совместное использование</li><li><a href="parallel-channel.send.php">parallel\Channel::send</a> — Совместное использование</li><li><a href="parallel-channel.close.php">parallel\Channel::close</a> — Закрытие</li></ul></li><li><a href="class.parallel-events.php">parallel\Events</a> — Класс parallel\Events<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-events.setblocking.php">parallel\Events::setBlocking</a> — Поведение</li><li><a href="parallel-events.settimeout.php">parallel\Events::setTimeout</a> — Поведение</li><li><a href="parallel-events.setinput.php">parallel\Events::setInput</a> — Вход</li><li><a href="parallel-events.addchannel.php">parallel\Events::addChannel</a> — Цели</li><li><a href="parallel-events.addfuture.php">parallel\Events::addFuture</a> — Цели</li><li><a href="parallel-events.remove.php">parallel\Events::remove</a> — Цели</li><li><a href="parallel-events.poll.php">parallel\Events::poll</a> — Опрос</li></ul></li><li><a href="class.parallel-events-input.php">parallel\Events\Input</a> — Класс parallel\Events\Input<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-events-input.add.php">parallel\Events\Input::add</a> — Входы</li><li><a href="parallel-events-input.clear.php">parallel\Events\Input::clear</a> — Входы</li><li><a href="parallel-events-input.remove.php">parallel\Events\Input::remove</a> — Входы</li></ul></li><li><a href="class.parallel-events-event.php">parallel\Events\Event</a> — Класс parallel\Events\Event</li><li><a href="class.parallel-events-event-type.php">parallel\Events\Event\Type</a> — Класс parallel\Events\Event\Type</li><li><a href="class.parallel-sync.php">parallel\Sync</a> — Класс parallel\Sync<ul class="chunklist chunklist_book chunklist_children"><li><a href="parallel-sync.construct.php">parallel\Sync::__construct</a> — Конструктор класса</li><li><a href="parallel-sync.get.php">parallel\Sync::get</a> — Доступ</li><li><a href="parallel-sync.set.php">parallel\Sync::set</a> — Доступ</li><li><a href="parallel-sync.wait.php">parallel\Sync::wait</a> — Синхронизация</li><li><a href="parallel-sync.notify.php">parallel\Sync::notify</a> — Синхронизация</li><li><a href="parallel-sync.invoke.php">parallel\Sync::__invoke</a> — Синхронизация</li></ul></li></ul></div><?php manual_footer($setup); ?>