1 |
#!/usr/bin/perl |
2 |
|
3 |
# ->resume is not exactly cheap (it saves/restores a LOT |
4 |
# of global variables), but shouldn't be slow. just to show |
5 |
# how fast it is, this little proggie compares a normal subroutine |
6 |
# call with two calls of transfer in a loop. |
7 |
|
8 |
use Coro; |
9 |
use Benchmark; |
10 |
|
11 |
$a = bless {}, main::; |
12 |
|
13 |
|
14 |
sub a { |
15 |
$n++; # do something to taint the benchmark results ;) |
16 |
} |
17 |
|
18 |
$b = new Coro sub { |
19 |
# do a little unrolling... |
20 |
while() { |
21 |
yield; yield; yield; yield; yield; |
22 |
} |
23 |
}; |
24 |
|
25 |
yield; |
26 |
|
27 |
$main = $Coro::main; |
28 |
|
29 |
*transfer = \&Coro::State::transfer; |
30 |
|
31 |
$c = Coro::State::newprocess { |
32 |
while() { |
33 |
transfer($c, $main); transfer($c, $main); |
34 |
transfer($c, $main); transfer($c, $main); |
35 |
} |
36 |
}; |
37 |
|
38 |
transfer($main, $c); |
39 |
|
40 |
timethese 100000, { |
41 |
method => '$a->a; $a->a; $a->a; $a->a', |
42 |
resume => 'yield; yield', |
43 |
transfer => 'transfer($main, $c); transfer($main, $c)', |
44 |
}; |