PHP 8.4.1 Released!

array_uintersect_uassoc

(PHP 5, PHP 7, PHP 8)

array_uintersect_uassocComputes the intersection of arrays with additional index check, compares data and indexes by separate callback functions

Опис

array_uintersect_uassoc(
    array $array1,
    array ...$arrays,
    callable $value_compare_func,
    callable $key_compare_func
): array

Computes the intersection of arrays with additional index check, compares data and indexes by separate callback functions.

Параметри

array1

The first array.

arrays

Further arrays.

value_compare_func

Порівняльна функція має повертати ціле число, котре менше, рівне або більше нуля, якщо перший параметр вважається відповідно меншим, рівним або більшим за другий.

callback(mixed $a, mixed $b): int
Застереження

Якщо функція порівняння повертає не цілі значення, такі як float, вони будуть приведені до типу int під час повернення з функції зворотнього виклику. Тож значення, схожі на 0.99 або 0.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;
};
?>

key_compare_func

Key comparison callback function.

Значення, що повертаються

Returns an array containing all the values of array1 that are present in all the arguments.

Приклади

Приклад #1 array_uintersect_uassoc() example

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

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

Поданий вище приклад виведе:

Array
(
    [a] => green
    [b] => brown
)

Прогляньте також

  • array_uintersect() - Computes the intersection of arrays, compares data by a callback function
  • array_intersect_assoc() - Computes the intersection of arrays with additional index check
  • array_intersect_uassoc() - Computes the intersection of arrays with additional index check, compares indexes by a callback function
  • array_uintersect_assoc() - Computes the intersection of arrays with additional index check, compares data by a callback function

add a note

User Contributed Notes 1 note

up
2
aidan at php dot net
20 years ago
Please note, the correct function synopsis is:

array array_uintersect_uassoc ( array array1, array array2 [, array ...], callback data_compare_func, callback key_compare_func)

You may specifiy as many arrays as you like, but the last two parameters must be valid call back functions.
To Top