TABLE OF CONTENTS

NAME

Mojo::Reactor - 低级别事件反应器的基类

SYNOPSIS

package Mojo::Reactor::MyEventLoop;
use Mojo::Base 'Mojo::Reactor';

sub again      {...}
sub io         {...}
sub is_running {...}
sub one_tick   {...}
sub recurring  {...}
sub remove     {...}
sub reset      {...}
sub start      {...}
sub stop       {...}
sub timer      {...}
sub watch      {...}

DESCRIPTION

Mojo::Reactor 是一个低级别事件反应堆的抽象出来的基类, 象 Mojo::Reactor::EVMojo::Reactor::Poll.

EVENTS

Mojo::Reactor 继承全部的 Mojo::EventEmitter 的事件并可以使用下面这些.

error

$reactor->on(error => sub {
  my ($reactor, $err) = @_;
  ...
});

如果是未处理的致命异常, 会调用这个错误回调. 需要注意的是, 如果本次事件是未处理或失败, 可能会杀死你的程序, 所以你需要小心.

$reactor->on(error => sub {
  my ($reactor, $err) = @_;
  say "Something very bad happened: $err";
});

METHODS

Mojo::Reactor 继承全部的 Mojo::EventEmitter 的方法并实现了下面这些.

again

$reactor->again($id);

重启 timer. 意味着要重载的子类. 注意, 此方法需要一个活的 timer.

detect

my $class = Mojo::Reactor->detect;

用于发现和检查最合适的可用的事件反应堆. 会尝试 MOJO_REACTOR 环境变量中的值, 比如 Mojo::Reactor::EV 或者 Mojo::Reactor::Poll.

# 最好的实例化中可用的事件反应堆
my $reactor = Mojo::Reactor->detect->new;

io

$reactor = $reactor->io($handle => sub {...});

监控 I/O 句柄事件, 当事件是可读或者可写的时候, 调用回调. 需要重载的子类.

# 回调将被调用两次,如果句柄即可读取或者写入
$reactor->io($handle => sub {
  my ($reactor, $writable) = @_;
  say $writable ? 'Handle is writable' : 'Handle is readable';
});

is_running

my $bool = $reactor->is_running;

检查反应堆是否运行.

next_tick

my $undef = $reactor->next_tick(sub {...});

尽快调用回调, 如果没有返回之前会返回 undef.

one_tick

$reactor->one_tick;

运行反应堆直到有事件发行. 注意这方法可以递归回反应堆, 所以你需要小心.

# Don't block longer than 0.5 seconds
my $id = $reactor->timer(0.5 => sub {});
$reactor->one_tick;
$reactor->remove($id);

recurring

my $id = $reactor->recurring(0.25 => sub {...});

创建一个循环的 timer, 在指定的间隔时间调用回调.

remove

my $bool = $reactor->remove($handle);
my $bool = $reactor->remove($id);

删除句柄或者 timer.

reset

$reactor->reset;

删除全部的句柄或者 timer.

start

$reactor->start;

开始监控 I/O 和 timer 事件, 这会阻塞直到 "stop" 被调用. 注意有些反应堆是会在没事件的时候自动停止的.

# 只有当它尚未运行的时候, 启动反应堆
$reactor->start unless $reactor->is_running;

stop

$reactor->stop;

停止监控 I/O 和 timer 事件.

timer

my $id = $reactor->timer(0.5 => sub {...});

创建一个新的 timer. 在指定的时间后调用回调.

watch

$reactor = $reactor->watch($handle, $readable, $writable);

对于 I/O 事件上创建监控, 指定 true 和 false 的值. 注意这需要一个活动的 I/O 监控者.

# 监控只读事件
$reactor->watch($handle, 1, 0);

# 监控写事件
$reactor->watch($handle, 0, 1);

# 监控可读和可写
$reactor->watch($handle, 1, 1);

# 停止监控事件 
$reactor->watch($handle, 0, 0);

SEE ALSO

Mojolicious, Mojolicious::Guides, http://mojolicio.us.