array_uintersect_uassoc

データと添字の比較に個別のコールバック関数を用い、 追加された添字の確認も含めて配列の共通項を計算する

説明

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

データと添字の比較にそれぞれ別のコールバック関数を用い、 追加された添字の確認も含めて配列の共通項を計算します。

パラメータ

array1

最初の配列。

arrays

残りの配列。

value_compare_func

比較関数は、最初の引数と二番目の引数の比較結果を返します。最初の引数のほうが二番目の引数より大きい場合は正の整数を、二番目の引数と等しい場合はゼロを、そして二番目の引数より小さい場合は負の整数を返す必要があります。

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

float のような 非整数 を比較関数が返すと、その返り値を内部的に 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;
};
?>

key_compare_func

キーの比較用のコールバック関数。

戻り値

全ての引数に現れる array1 の全ての値を含む配列を返します。

例1 array_uintersect_uassoc の例

<?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
  • array_intersect_assoc
  • array_intersect_uassoc
  • array_uintersect_assoc