如果您正在处理大型数组并且发现使用array_search()和array_column()在性能方面很慢,则可以考虑以下方法:
避免在循环中使用array_search(),因为这会导致性能下降。在循环中使用array_key_exists()或isset()来检查一个键是否存在会更快一些。
如果您需要查找数组中的多个值,则可以使用array_intersect()或array_diff()函数来代替array_search()。
如果您需要从数组中获取一个列的值,则可以使用foreach循环并将每个元素的值添加到新数组中。这个方法可能会比array_column()函数更快。
以下示例演示了如何改进这个问题的性能:
// 使用 array_search() 和 array_column() $users = [ ['id' => 1, 'name' => 'John', 'age' => 25], ['id' => 2, 'name' => 'Jane', 'age' => 30], ['id' => 3, 'name' => 'Bob', 'age' => 40] ];
$search_key = 'name'; $search_value = 'Jane';
$key = array_search($search_value, array_column($users, $search_key));
// 改进后的代码 $users = [ ['id' => 1, 'name' => 'John', 'age' => 25], ['id' => 2, 'name' => 'Jane', 'age' => 30], ['id' => 3, 'name' => 'Bob', 'age' => 40] ];
$search_key = 'name'; $search_value = 'Jane';
foreach ($users as $user) { if ($user[$search_key] === $search_value) { $key = $user['id']; break; } }
在这个例子中,我们使用foreach循环而不是array_search()来查找数组中的值,这会提高性能并减