Home >Backend Development >PHP Tutorial >Is `isset` Faster than `in_array` for Checking Array Elements?

Is `isset` Faster than `in_array` for Checking Array Elements?

Susan Sarandon
Susan SarandonOriginal
2024-11-11 11:02:03489browse

Is `isset` Faster than `in_array` for Checking Array Elements?

Speed Comparison: in_array vs. isset

When working with large arrays, it's crucial to optimize code performance. Which is faster: the in_array function or the isset construct?

in_array:

This function performs a linear search, iterating through the array to find a match. It has a time complexity of O(n), where n is the size of the array.

isset:

isset, on the other hand, uses a hash search to determine if a particular key exists in an associative array. This makes it much faster than in_array, with a constant time complexity of O(1).

Performance Test:

To demonstrate this speed difference, we can conduct a benchmark:

$a = array();
for ($i = 0; $i < 10000; ++$i) {
    $v = rand(1, 1000000);
    $a[$v] = $v;
}

$start = microtime(true);

for ($i = 0; $i < 10000; ++$i) {
    isset($a[rand(1, 1000000)]);
}

$total_time = microtime(true) - $start;
echo "isset: " . number_format($total_time, 6) . PHP_EOL;

$start = microtime(true);

for ($i = 0; $i < 10000; ++$i) {
    in_array(rand(1, 1000000), $a);
}

$total_time = microtime(true) - $start;
echo "in_array: " . number_format($total_time, 6) . PHP_EOL;

Results:

The test results show that isset is significantly faster than in_array, demonstrating the advantage of its constant time complexity.

Conclusion:

When checking for the existence of elements in an array, isset is the preferred choice due to its faster performance. However, if the order of elements is important, then in_array should be used as it preserves the element order.

The above is the detailed content of Is `isset` Faster than `in_array` for Checking Array Elements?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn