таймер — Как установить procss заблокированным для ожидания сигнала в переполнении стека

Я пишу сценарий Timer, используя сигнал. Каждую 1 секунду отправляю SIGALRM процессу, затем перехватываю сигнал и проверяю, есть ли задача для выполнения.
Я использую pcntl_alarm (1), чтобы послать сигнал, но процесс excute-and-quit, прежде чем получить сигнал.
Я думаю, есть ли способ установить блокировку prcess в ожидании сигнала. Я использовал base_event, но он очень тяжелый.
Так что любой может мне помочь. Большое спасибо.

Это мой сценарий (извините за chinesse ^ _ ^):

<?php
/**
*定时器
*/
class Timer
{
//保存所有定时任务
public static $task = array();

//定时间隔
public static $time = 1;

/**
*开启服务
*@param $time int
*/
public static function run($time = null)
{
if($time)
{
self::$time = $time;
}
self::installHandler();
pcntl_alarm(1);
do{ sleep(2); }while(true);
}
/**
*注册信号处理函数
*/
public static function installHandler()
{
echo "installHandler\n";
pcntl_signal(SIGALRM, array('Timer','signalHandler'),false);
pcntl_alarm(1);
}

/**
*信号处理函数
*/
public static function signalHandler()
{
self::task();
}

/**
*执行回调
*/
public function task()
{
if(empty(self::$task))
{
return ;
}
foreach(self::$task as $time => $arr)
{
$current = time();
$func = $arr['func'];
$argv = $arr['argv'];
$interval = $arr['interval'];
$persist = $arr['persist'];

if($current == $time)
{
call_user_func_array($func, $argv);
}
if($persist)
{
self::$task[$current+$interval] = $arr;
}
unset(self::$task[$time]);
}
pcntl_alarm(self::$time);
}

/**
*添加任务
public static function add($interval, $func, $argv,$persist =     false)
{
if(is_null($interval))
{
return;
}
$time = time()+$interval;
self::$task[$time] = array('func'=>$func, 'argv'=>$argv, 'interval'=>$interval, 'persist'=>$persist);
}

/**
*删除所有定时器任务
*/
public function dellAll()
{
self::$task = array();
}
}

3

Решение

Теперь я знаю ответ, хотя так много раз прошло, потому что у меня были другие работы, чтобы закончить … извините за опоздание. Так что мой ответ очень прост.

спать

подходит для блокировки процесса, тогда процесс получает сигнал, и то, что я пропустил, никогда не захватывает его … так что используйте

pcntl_signal_dispatch

Функция в цикле именно так.

0

Другие решения

Других решений пока нет …