Files
php-doc-ru/reference/array/functions/array-merge.xml
2024-10-04 11:08:59 +03:00

241 lines
6.5 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: 8859c8b96cd9e80652813f7bcf561432a5e9f934 Maintainer: shein Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.array-merge" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>array_merge</refname>
<refpurpose>Сливает один или несколько массивов</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>array</type><methodname>array_merge</methodname>
<methodparam rep="repeat"><type>array</type><parameter>arrays</parameter></methodparam>
</methodsynopsis>
<para>
Функция сливает элементы одного или нескольких массивов так,
что значения одного добавляются в конец предыдущего.
Функция возвращает результирующий массив.
</para>
<para>
Каждое следующее значение ключа перезапишет предыдущее,
если входные массивы содержат одинаковые строковые ключи.
Следующее значение <emphasis role="strong">не перезапишет</emphasis> исходное,
а добавится в конец массива, если массивы содержат одинаковые числовые ключи.
</para>
<para>
В массиве с результатами функция перенумерует возрастающими ключами начиная с нуля
значения входных массивов с числовыми ключами.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>arrays</parameter></term>
<listitem>
<para>
Список массивов для слияния.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Функция возвращает результирующий массив.
Без аргументов функция возвращает пустой массив (&array;).
</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>7.4.0</entry>
<entry>
Теперь функция умеет работать без аргументов.
Раньше требовался хотя бы один аргумент.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Пример слияния массивов функцией <function>array_merge</function></title>
<programlisting role="php">
<![CDATA[
<?php
$array1 = array("color" => "red", 2, 4);
$array2 = array("a", "b", "color" => "green", "shape" => "trapezoid", 4);
$result = array_merge($array1, $array2);
print_r($result);
?>
]]>
</programlisting>
&example.outputs;
<screen role="php">
<![CDATA[
Array
(
[color] => green
[0] => 2
[1] => 4
[2] => a
[3] => b
[shape] => trapezoid
[4] => 4
)
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Простой пример слияния массивов функцией <function>array_merge</function></title>
<programlisting role="php">
<![CDATA[
<?php
$array1 = array();
$array2 = array(1 => "data");
$result = array_merge($array1, $array2);
?>
]]>
</programlisting>
<para>
Помните, что функция перенумерует числовые ключи!
</para>
<screen role="php">
<![CDATA[
Array
(
[0] => data
)
]]>
</screen>
<para>
Элементы второго массива добавляются в первый массив
без перезаписи элементов первого массива и без переиндексации
оператором объединения массивов — <literal>+</literal>:
</para>
<programlisting role="php">
<![CDATA[
<?php
$array1 = array(0 => 'zero_a', 2 => 'two_a', 3 => 'three_a');
$array2 = array(1 => 'one_b', 3 => 'three_b', 4 => 'four_b');
$result = $array1 + $array2;
var_dump($result);
?>
]]>
</programlisting>
<para>
Функция сохранит ключи первого массива. Функция возьмёт элемент
первого массива, а элемент второго проигнорирует,
если оба массива содержат одинаковый ключ.
</para>
<screen role="php">
<![CDATA[
array(5) {
[0]=>
string(6) "zero_a"
[2]=>
string(5) "two_a"
[3]=>
string(7) "three_a"
[1]=>
string(5) "one_b"
[4]=>
string(6) "four_b"
}
]]>
</screen>
</example>
</para>
<para>
<example>
<title>
Пример слияния функцией <function>array_merge</function> значений,
тип которых не принадлежит массиву
</title>
<programlisting role="php">
<![CDATA[
<?php
$beginning = 'foo';
$end = array(1 => 'bar');
$result = array_merge((array) $beginning, (array) $end);
print_r($result);
?>
]]>
</programlisting>
&example.outputs;
<screen role="php">
<![CDATA[
Array
(
[0] => foo
[1] => bar
)
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>array_merge_recursive</function></member>
<member><function>array_replace</function></member>
<member><function>array_combine</function></member>
<member><link linkend="language.operators.array">Операторы работы с массивами</link></member>
</simplelist>
</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
-->