1
0
mirror of https://github.com/php/doc-ru.git synced 2026-03-23 23:32:16 +01:00
Files
archived-doc-ru/reference/ds/ds.deque.xml
2024-06-17 02:23:57 +03:00

168 lines
5.5 KiB
XML
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 4d17b7b4947e7819ff5036715dd706be87ae4def Maintainer: rjhdby Status: ready -->
<!-- Reviewed: no -->
<reference xml:id="class.ds-deque" role="class" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude">
<title>Класс Deque</title>
<titleabbrev>Ds\Deque</titleabbrev>
<partintro>
<!-- {{{ Ds\Deque intro -->
<section xml:id="ds-deque.intro">
&reftitle.intro;
<para>
Двухсторонняя очередь — последовательность значений в непрерывном буфере,
который растёт и уменьшаются автоматически.
Deque (произносится как «deck») — аббревиатура от «double-ended queue»
и используется внутри структуры <classname>Ds\Queue</classname>.
</para>
<para>
Для отслеживания начала и конца используются два указателя. Указатели могут
«обтекать» конец буфера, что помогает избежать перемещения
значений для освобождения места. Это делает операции shift и unshift такими быстрыми,
что структура <classname>Ds\Vector</classname> не может с этим соперничать.
</para>
<para>
Доступ к элементу по индексу требует пересчёта в зависимости от его индекса в буфере:
<code>((head + position) % capacity)</code>.
</para>
</section>
<!-- }}} -->
<section xml:id="ds-deque.strengths">
<title xmlns="http://docbook.org/ns/docbook">Сильные стороны</title>
<para>
<simplelist>
<member>Поддерживает синтаксис массива (квадратные скобки).</member>
<member>Требует меньше памяти, чем массив (&array;) с тем же количеством значений.</member>
<member>Автоматически освобождает память, когда количество элементов уменьшается.</member>
<member>
<function>get</function>,
<function>set</function>,
<function>push</function>,
<function>pop</function>,
<function>shift</function>
и <function>unshift</function> имеют сложность O(1).
</member>
</simplelist>
</para>
</section>
<section xml:id="ds-deque.weaknesses">
<title xmlns="http://docbook.org/ns/docbook">Слабые стороны</title>
<para>
<simplelist>
<member>Вместимость ограничена степенями двойки.</member>
<member>
<function>insert</function> и
<function>remove</function> имеют сложность O(n).
</member>
</simplelist>
</para>
</section>
<section xml:id="ds-deque.synopsis">
&reftitle.classsynopsis;
<!-- {{{ Synopsis -->
<classsynopsis>
<ooclass><classname>Ds\Deque</classname></ooclass>
<!-- {{{ Class synopsis -->
<classsynopsisinfo>
<ooclass>
<classname>Ds\Deque</classname>
</ooclass>
<oointerface>
<interfacename>Ds\Sequence</interfacename>
</oointerface>
<oointerface>
<interfacename>ArrayAccess</interfacename>
</oointerface>
</classsynopsisinfo>
<!-- }}} -->
<classsynopsisinfo role="comment">&Constants;</classsynopsisinfo>
<fieldsynopsis>
<modifier>const</modifier>
<type>int</type>
<varname linkend="ds-deque.constants.min-capacity">Ds\Deque::MIN_CAPACITY</varname>
<initializer>8</initializer>
</fieldsynopsis>
<classsynopsisinfo role="comment">&Methods;</classsynopsisinfo>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.ds-deque')/db:refentry/db:refsect1[@role='description']/descendant::db:methodsynopsis)">
<xi:fallback/>
</xi:include>
</classsynopsis>
<!-- }}} -->
</section>
<!-- {{{ Ds\Deque constants -->
<section xml:id="ds-deque.constants">
&reftitle.constants;
<variablelist>
<varlistentry xml:id="ds-deque.constants.min-capacity">
<term><constant>Ds\Deque::MIN_CAPACITY</constant></term>
<listitem>
<para></para>
</listitem>
</varlistentry>
</variablelist>
</section>
<!-- }}} -->
<section role="changelog">
&reftitle.changelog;
<para>
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>PECL ds 1.3.0</entry>
<entry>
Теперь класс реализует интерфейс <classname>ArrayAccess</classname>.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</section>
</partintro>
&reference.ds.ds.entities.deque;
</reference>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->