-
-
Notifications
You must be signed in to change notification settings - Fork 46
Expand file tree
/
Copy pathRemovePriorityQueueBench.php
More file actions
44 lines (35 loc) · 1.02 KB
/
RemovePriorityQueueBench.php
File metadata and controls
44 lines (35 loc) · 1.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<?php
declare(strict_types=1);
namespace LaminasBench\Stdlib;
use Laminas\Stdlib\FastPriorityQueue;
use Laminas\Stdlib\PriorityQueue;
use PhpBench\Attributes\Iterations;
use PhpBench\Attributes\Revs;
use PhpBench\Attributes\Warmup;
use function rand;
#[Revs(1000)]
#[Iterations(10)]
#[Warmup(2)]
final class RemovePriorityQueueBench
{
private FastPriorityQueue $fastPriorityQueue;
private PriorityQueue $priorityQueue;
public function __construct()
{
$this->fastPriorityQueue = new FastPriorityQueue();
$this->priorityQueue = new PriorityQueue();
for ($i = 0; $i < 1000; $i += 1) {
$priority = rand(1, 100);
$this->fastPriorityQueue->insert('foo', $priority);
$this->priorityQueue->insert('foo', $priority);
}
}
public function benchRemovePriorityQueue(): void
{
$this->priorityQueue->remove('foo');
}
public function benchRemoveFastPriorityQueue(): void
{
$this->fastPriorityQueue->remove('foo');
}
}