Files
php-doc-ru/reference/spl/functions/iterator-to-array.xml
Alexey Pyltsyn 0057a44d6e Upd
git-svn-id: https://svn.php.net/repository/phpdoc/ru/trunk@343995 c90b9560-bf6c-de11-be94-00142212c4b1
2018-01-28 08:52:19 +00:00

168 lines
4.9 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: b8758b0605e80c4e3610137b7502a6abeea5c69b Maintainer: rjhdby Status: ready -->
<!-- Reviewed: yes -->
<!-- $Revision$ -->
<refentry xml:id="function.iterator-to-array" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>iterator_to_array</refname>
<refpurpose>Копирует итератор в массив</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>array</type><methodname>iterator_to_array</methodname>
<methodparam><type>Traversable</type><parameter>iterator</parameter></methodparam>
<methodparam choice="opt"><type>bool</type><parameter>use_keys</parameter><initializer>&true;</initializer></methodparam>
</methodsynopsis>
<para>
Копирует элементы итератора в массив.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>iterator</parameter></term>
<listitem>
<para>
Копируемый итератор.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>use_keys</parameter></term>
<listitem>
<para>
Следует ли использовать ключи элементов итератора как индексы.
</para>
<para>
В PHP 5.5 и новее, если ключ является массивом (<type>array</type>) или
объектом (<type>object</type>), то бросается предупреждение.
Ключи со значением &null; преобразуются в пустую строку,
ключи в виде чисел с плавающей точкой (<type>float</type>)
обрезаются до их целочисленных (<type>integer</type>) частей, ключи
с ресурсами (<type>resource</type>) бросают предупреждение и преобразуются
в их идентификаторы ресурса, а логические (<type>boolean</type>)
ключи преобразуются в целые числа.
</para>
<note>
<para>
Если параметр не задан, либо задан как &true;, дублирующиеся ключи будут
перезаписаны. Последнее значение с заданным ключем будет в результирующем
массиве. Установите этот параметр равным &false; для получения всех значений.
</para>
</note>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Массив, содержащий элементы <parameter>iterator</parameter>.
</para>
</refsect1>
<refsect1 role="changelog">
&reftitle.changelog;
<para>
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>5.5.0</entry>
<entry>
<function>iterator_to_array</function> стал поддерживать ключи с типами,
отличными от <type>integer</type> и <type>string</type>, если включен параметр
<parameter>use_keys</parameter>.
</entry>
</row>
<row>
<entry>5.2.1</entry>
<entry>
Добавлен параметр <parameter>use_keys</parameter>.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Пример использования <function>iterator_to_array</function></title>
<programlisting role="php">
<![CDATA[
<?php
$iterator = new ArrayIterator(array('recipe'=>'pancakes', 'egg', 'milk', 'flour'));
var_dump(iterator_to_array($iterator, true));
var_dump(iterator_to_array($iterator, false));
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
array(4) {
["recipe"]=>
string(8) "pancakes"
[0]=>
string(3) "egg"
[1]=>
string(4) "milk"
[2]=>
string(5) "flour"
}
array(4) {
[0]=>
string(8) "pancakes"
[1]=>
string(3) "egg"
[2]=>
string(4) "milk"
[3]=>
string(5) "flour"
}
]]>
</screen>
</example>
</para>
</refsect1>
</refentry>
<!-- 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
-->