1
0
mirror of https://github.com/php/doc-zh.git synced 2026-03-27 08:32:08 +01:00
Files
archived-doc-zh/reference/array/functions/array-intersect-ukey.xml

214 lines
6.4 KiB
XML
Executable File
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"?>
<!-- $Revision$ -->
<!-- EN-Revision: 5faa7a6747bca628b3bdcc9f93aec5603b65581f Maintainer: HonestQiao Status: ready -->
<!-- Reviewed: no Maintainer: HonestQiao -->
<refentry xml:id="function.array-intersect-ukey" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>array_intersect_ukey</refname>
<refpurpose>用回调函数比较键名来计算数组的交集</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>array</type><methodname>array_intersect_ukey</methodname>
<methodparam><type>array</type><parameter>array1</parameter></methodparam>
<methodparam><type>array</type><parameter>array2</parameter></methodparam>
<methodparam choice="opt"><type>array</type><parameter>...</parameter></methodparam>
<methodparam><type>callback</type><parameter>key_compare_func</parameter></methodparam>
</methodsynopsis>
<para>
<function>array_intersect_ukey</function> 返回一个数组,该数组包含了所有出现在
<parameter>array1</parameter> 中并同时出现在所有其它参数数组中的键名的值。
</para>
<para>
此比较是通过用户提供的回调函数来进行的。如果认为第一个参数小于,等于,或大于第二个参数时必须分别返回一个小于零,等于零,或大于零的整数。
</para>
<para>
<example>
<title><function>array_intersect_ukey</function> 例子</title>
<programlisting role="php">
<![CDATA[
<?php
function key_compare_func($key1, $key2)
{
if ($key1 == $key2)
return 0;
else if ($key1 > $key2)
return 1;
else
return -1;
}
$array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
$array2 = array('green' => 5, 'blue' => 6, 'yellow' => 7, 'cyan' => 8);
var_dump(array_intersect_ukey($array1, $array2, 'key_compare_func'));
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
array(2) {
["blue"]=>
int(1)
["green"]=>
int(3)
})
]]>
</screen>
</example>
</para>
<para>
上例中可以看到只有 <literal>'blue'</literal>
<literal>'green'</literal> 两个键名出现在两个数组中,因此被返回。此外注意
<literal>'blue'</literal><literal>'green'</literal>
的值在两个数组中是不同的。但因为只检查键名,因此还是匹配。返回的值只是
<parameter>array1</parameter> 中的。
</para>
<para>
参见 <function>array_diff</function><function>array_udiff</function><function>array_diff_assoc</function><function>array_diff_uassoc</function><function>array_udiff_assoc</function><function>array_udiff_uassoc</function><function>array_diff_key</function><function>array_diff_ukey</function><function>array_intersect</function><function>array_intersect_assoc</function><function>array_intersect_uassoc</function>
<function>array_intersect_key</function>
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>array1</parameter></term>
<listitem>
<para>
Initial array for comparison of the arrays.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>array2</parameter></term>
<listitem>
<para>
First array to compare keys against.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>array</parameter></term>
<listitem>
<para>
Variable list of array arguments to compare keys against.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>key_compare_func</parameter></term>
<listitem>
<para>
&return.callbacksort;
</para>
&callback.cmp;
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Returns the values of <parameter>array1</parameter> whose keys exist
in all the arguments.
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title><function>array_intersect_ukey</function> example</title>
<programlisting role="php">
<![CDATA[
<?php
function key_compare_func($key1, $key2)
{
if ($key1 == $key2)
return 0;
else if ($key1 > $key2)
return 1;
else
return -1;
}
$array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
$array2 = array('green' => 5, 'blue' => 6, 'yellow' => 7, 'cyan' => 8);
var_dump(array_intersect_ukey($array1, $array2, 'key_compare_func'));
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
array(2) {
["blue"]=>
int(1)
["green"]=>
int(3)
}
]]>
</screen>
</example>
</para>
<para>
In our example you see that only the keys <literal>'blue'</literal>
and <literal>'green'</literal> are present in both arrays and thus
returned. Also notice that the values for the keys
<literal>'blue'</literal> and <literal>'green'</literal> differ between
the two arrays. A match still occurs because only the keys are checked.
The values returned are those of <parameter>array1</parameter>.
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>array_diff</function></member>
<member><function>array_udiff</function></member>
<member><function>array_diff_assoc</function></member>
<member><function>array_diff_uassoc</function></member>
<member><function>array_udiff_assoc</function></member>
<member><function>array_udiff_uassoc</function></member>
<member><function>array_diff_key</function></member>
<member><function>array_diff_ukey</function></member>
<member><function>array_intersect</function></member>
<member><function>array_intersect_assoc</function></member>
<member><function>array_intersect_uassoc</function></member>
<member><function>array_intersect_key</function></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
-->