zoukankan      html  css  js  c++  java
  • PHP declare(ticks=N); 的作用

      一般用法是 declare(ticks=N);拿declare(ticks=1)来说,这句主要作用有两种:

      1、Zend引擎每执行1条低级语句就去执行一次 register_tick_function() 注册的函数。可以粗略的理解为每执行一句php代码(例如:$num=1;)就去执行下已经注册的tick函数。 一个用途就是控制某段代码执行时间,例如下面的代码虽然最后有个死循环,但是执行时间不会超过5秒。运行 php timeout.php

     1 <?php
     2 declare(ticks=1);
     3 
     4 // 开始时间
     5 $time_start = time();
     6 
     7 // 检查是否已经超时
     8 function check_timeout(){
     9     // 开始时间
    10     global $time_start;
    11     // 5秒超时
    12     $timeout = 5;
    13     if(time()-$time_start > $timeout){
    14         exit("超时{$timeout}秒
    ");
    15     }
    16 }
    17 
    18 // Zend引擎每执行一次低级语句就执行一下check_timeout
    19 register_tick_function('check_timeout');
    20 
    21 // 模拟一段耗时的业务逻辑
    22 while(1){
    23    $num = 1;
    24 }
    25 
    26 // 模拟一段耗时的业务逻辑,虽然是死循环,但是执行时间不会超过$timeout=5秒
    27 while(1){
    28    $num = 1;
    29 }

      2、declare(ticks=1);每执行一次低级语句会检查一次该进程是否有未处理过的信号,测试代码如下:

     1 <?php
     2 declare(ticks = 1); //每执行一次低级语句会检查一次该进程是否有未处理过的信号,
     3 
     4 //利用计时器发送一个SIGALRM信号
     5 function signal_handler($signal){
     6     print "Caught SIGALRM
    ";
     7     pcntl_alarm(5);
     8 }
     9 
    10 pcntl_signal(SIGALRM, "signal_handler");
    11 pcntl_alarm(5);
    12 
    13 while (1){
    14     sleep(1);
    15 }

      当然declare的效率是极低的,比较好的做法是去掉ticks,转而使用pcntl_signal_dispatch,在代码循环中自行处理信号. 具体参考:http://rango.swoole.com/archives/364

      优化上述例子:

     1 <?php
     2 //declare(ticks = 1); //每执行一次低级语句会检查一次该进程是否有未处理过的信号,效率太低
     3 
     4 //利用计时器发送一个SIGALRM信号
     5 function signal_handler($signal){
     6     print "Caught SIGALRM
    ";
     7     pcntl_alarm(5);
     8 }
     9 
    10 pcntl_signal(SIGALRM, "signal_handler");
    11 //5秒后发送信号
    12 pcntl_alarm(5);
    13 
    14 while (1){
    15     pcntl_signal_dispatch();
    16     sleep(1);
    17 }

       参考:http://blog.csdn.net/udefined/article/details/24333333

          http://rango.swoole.com/archives/364      

  • 相关阅读:
    hadoop自定义数据类型
    hadoop worldcount小程序
    windows下eclipse连接ubuntu伪分布式hadoop2.6.0
    Hadoop2.6.0伪分布式搭建
    解决hadoop no dataNode to stop问题
    hadoop 2.6.0 伪分布式部署安装遇到的问题
    Hadoop执行bin/stop-all.sh时no namenode to stop异常
    Hadoop伪分布式安装步骤(hadoop0.20.2版本)
    《Hadoop基础教程》之初识Hadoop(转载)
    自定义Json格式
  • 原文地址:https://www.cnblogs.com/loveyouyou616/p/5799933.html
Copyright © 2011-2022 走看看