PHP 8.4.1 Released!

array_uintersect_assoc

(PHP 5, PHP 7, PHP 8)

array_uintersect_assoc带索引检查计算数组的交集,用回调函数比较数据

说明

array_uintersect_assoc(array $array, array ...$arrays, callable $value_compare_func): array

此比较是通过用户提供的回调函数来进行的。如果认为第一个参数小于,等于,或大于第二个参数时必须分别返回一个小于零,等于零,或大于零的整数。

注意和 array_uintersect() 不同的是键名也要比较。数据是用回调函数比较的。

参数

array

第一个数组。

arrays

要比较的数组。

value_compare_func

在第一个参数小于,等于或大于第二个参数时,该比较函数必须相应地返回一个小于,等于或大于 0 的整数。

callback(mixed $a, mixed $b): int
警告

从比较函数中返回非整数值,例如 float,将导致内部强制转换为 callback 返回值为 int。因此,诸如 0.990.1 之类的值都将被转换为整数值 0,将这些值比较的话将会是相等。

警告

排序回调必须以任意顺序处理任意数组中的任意值,无论它们最初提供的顺序如何。这是因为每个单独的数组在与其他数组进行比较之前首先进行排序。例如:

<?php
$arrayA
= ["string", 1];
$arrayB = [["value" => 1]];
// $item1 和 $item2 可以是“string”、1 或 ["value" => 1]
$compareFunc = static function ($item1, $item2) {
$value1 = is_string($item1) ? strlen($item1) : (is_array($item1) ? $item1["value"] : $item1);
$value2 = is_string($item2) ? strlen($item2) : (is_array($item2) ? $item2["value"] : $item2);
return
$value1 <=> $value2;
};
?>

返回值

返回一个数组,该数组包含了所有在 array 中也同时出现在所有其它参数数组中的值。

示例

示例 #1 array_uintersect_assoc() 示例

<?php
$array1
= array("a" => "green", "b" => "brown", "c" => "blue", "red");
$array2 = array("a" => "GREEN", "B" => "brown", "yellow", "red");

print_r(array_uintersect_assoc($array1, $array2, "strcasecmp"));
?>

以上示例会输出:

Array
(
    [a] => green
)

参见

添加备注

用户贡献的备注

此页面尚无用户贡献的备注。
To Top