PERL 的线程模块似乎不适用于 Irssi。
我无法获得更多信息,因为#Irssi 的人从未回应。
我需要让脚本每 5 分钟检查一次数据库。
现在我认为这在 PERL 中使用多线程是可能的,但是一旦包含模块 Irssi 将抛出异常。
具有讽刺意味的是,如果我尝试构建一个 while 循环,该循环会在 Irssi 客户端挂起一段时间后自行终止。
有什么建议么?
代码
use strict;
use warnings;
use threads;
use Thread::Queue;
my $q = Thread::Queue->new(); # A new empty queue
# Worker thread
my $thr = threads->create(
sub {
# Thread will loop until no more work
while (defined(my $item = $q->dequeue())) {
# Do work on $item
}
}
);
Irssi 中的错误(不是全部,但同样的事情,找不到包):
13:30| Can't locate package Irssi::ServerSetup for
@Irssi::Irc::ServerSetup::ISA at
/home/nullby7e/.irssi/scripts/test.pl line 27.
13:30|
13:30| Can't locate package Irssi::Nick for @Irssi::Irc::Nick::ISA at
/home/nullby7e/.irssi/scripts/test.pl line 27.
13:30|
13:30| Can't locate package Irssi::ServerConnect for
@Irssi::Irc::ServerConnect::ISA at
/home/nullby7e/.irssi/scripts/test.pl line 27.
最佳答案
我无法帮助您处理线程,但是根据 Irssi Perl Scripting Reference 您需要 Irssi::timeout_add
函数。
您可以在 Irssi's Script Repository 找到许多如何使用它的示例。基本用法是:
use Irssi;
sub check_database {
...
}
Irssi::timeout_add(5*60*1000, "check_database", undef);
关于multithreading - 在 Irssi 中使用 PERL 进行线程处理,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/24834680/