array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ru', ), 'this' => array ( 0 => 'class.ds-deque.php', 1 => 'Ds\\Deque', ), 'up' => array ( 0 => 'book.ds.php', 1 => 'Структуры данных', ), 'prev' => array ( 0 => 'ds-vector.unshift.php', 1 => 'Ds\\Vector::unshift', ), 'next' => array ( 0 => 'ds-deque.allocate.php', 1 => 'Ds\\Deque::allocate', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ru', 'path' => 'reference/ds/ds.deque.xml', ), 'extra_header_links' => array ( 'rel' => 'alternate', 'href' => '/manual/en/feeds/class.ds-deque.atom', 'type' => 'application/atom+xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PECL ds >= 1.0.0)
Двухсторонняя очередь - это последовательность значений в непрерывном буфере, который растёт и уменьшаются автоматически. Deque (произносится как "deck") является аббревиатурой от "double-ended queue" и используется внутри Ds\Queue.
Два указателя используются для отслеживания начала и конца. Указатели могут "обернуть" конец очереди, что позволяет избежать перемещения значений для освобождения места. Это делает операции shift и unshift такими быстрыми, что Ds\Vector не может с этим соперничать.
Доступ к элементу по индексу требует пересчёта в зависимости от его индекса в буфере:
((head + position) % capacity)
.