Files
php-doc-ru/reference/spl/splfixedarray.xml
2023-09-01 11:18:36 +03:00

204 lines
6.0 KiB
XML
Raw 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: 14767af0f05dffa6fdb9b49e1a1f4e9ca7022a60 Maintainer: shein Status: ready -->
<!-- Reviewed: no -->
<phpdoc:classref xml:id="class.splfixedarray" xmlns:phpdoc="http://php.net/ns/phpdoc" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude">
<title>Класс SplFixedArray</title>
<titleabbrev>SplFixedArray</titleabbrev>
<partintro>
<!-- {{{ splfixedarray intro -->
<section xml:id="splfixedarray.intro">
&reftitle.intro;
<para>
Класс SplFixedArray обеспечивает базовую функциональность,
предоставляемую массивами.
Главное различие между SplFixedArray и обычным массивом PHP в том,
что размер SplFixedArray необходимо изменять вручную, а в
качестве индексов могут выступать только целочисленные значения.
Преимущество данных ограничений заключается в меньшем использовании памяти, чем стандартный массив (<type>array</type>).
</para>
</section>
<!-- }}} -->
<section xml:id="splfixedarray.synopsis">
&reftitle.classsynopsis;
<!-- {{{ Synopsis -->
<classsynopsis class="class">
<ooclass>
<classname>SplFixedArray</classname>
</ooclass>
<oointerface>
<modifier>implements</modifier>
<interfacename>IteratorAggregate</interfacename>
</oointerface>
<oointerface>
<interfacename>ArrayAccess</interfacename>
</oointerface>
<oointerface>
<interfacename>Countable</interfacename>
</oointerface>
<oointerface>
<interfacename>JsonSerializable</interfacename>
</oointerface>
<classsynopsisinfo role="comment">&Methods;</classsynopsisinfo>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.splfixedarray')/db:refentry/db:refsect1[@role='description']/descendant::db:constructorsynopsis[@role='SplFixedArray'])">
<xi:fallback/>
</xi:include>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.splfixedarray')/db:refentry/db:refsect1[@role='description']/descendant::db:methodsynopsis[@role='SplFixedArray'])">
<xi:fallback/>
</xi:include>
</classsynopsis>
</section>
<section role="changelog">
&reftitle.changelog;
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>8.2.0</entry>
<entry>
Магические методы <methodname>SplFixedArray::__serialize</methodname> и
<methodname>SplFixedArray::__unserialize</methodname> добавлены
в <classname>SplFixedArray</classname>.
</entry>
</row>
<row>
<entry>8.1.0</entry>
<entry>
Класс <classname>SplFixedArray</classname> теперь реализует
интерфейс <interfacename>JsonSerializable</interfacename>.
</entry>
</row>
<row>
<entry>8.0.0</entry>
<entry>
Класс <classname>SplFixedArray</classname> теперь реализует
интерфейс <interfacename>IteratorAggregate</interfacename>.
Ранее был реализован интерфейс <interfacename>Iterator</interfacename>.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</section>
<!-- {{{ splfixedarray examples -->
<section xml:id="splfixedarray.examples">
&reftitle.examples;
<para>
<example>
<title>Пример использования <classname>SplFixedArray</classname></title>
<programlisting role="php">
<![CDATA[
<?php
// Инициализация массива фиксированной длиной
$array = new SplFixedArray(5);
$array[1] = 2;
$array[4] = "foo";
var_dump($array[0]); // NULL
var_dump($array[1]); // int(2)
var_dump($array["4"]); // string(3) "foo"
// Увеличение размера массива до 10
$array->setSize(10);
$array[9] = "asdf";
// Сокращаем размер массива до 2-х
$array->setSize(2);
// Следующий код вызывает исключение RuntimeException: Index invalid or out of range
try {
var_dump($array["non-numeric"]);
} catch(RuntimeException $re) {
echo "RuntimeException: ".$re->getMessage()."\n";
}
try {
var_dump($array[-1]);
} catch(RuntimeException $re) {
echo "RuntimeException: ".$re->getMessage()."\n";
}
try {
var_dump($array[5]);
} catch(RuntimeException $re) {
echo "RuntimeException: ".$re->getMessage()."\n";
}
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
NULL
int(2)
string(3) "foo"
RuntimeException: Index invalid or out of range
RuntimeException: Index invalid or out of range
RuntimeException: Index invalid or out of range
]]>
</screen>
</example>
</para>
</section>
<!-- }}} -->
<!-- {{{ splfixedarray properties
<section xml:id="splfixedarray.props">
&reftitle.properties;
<variablelist>
<varlistentry xml:id="splfixedarray.props.name">
<term><varname>name</varname></term>
<listitem>
<para>Prop description</para>
</listitem>
</varlistentry>
</variablelist>
</section>
}}} -->
</partintro>
&reference.spl.entities.splfixedarray;
</phpdoc:classref>
<!-- 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
-->