登录 |  注册 |  繁體中文


php declare详解

分类: php 颜色:橙色 默认  字号: 阅读(2475) | 评论(0)

declare和ticks可以用来做调试或性能测试。

一般用法是 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.  
  23. // 模拟一段耗时的业务逻辑,虽然是死循环,但是执行时间不会超过$timeout=5秒
  24. while(1){
  25.    $num = 1;
  26. }

2、declare(ticks=1);每执行一次低级语句会检查一次该进程是否有未处理过的信号,测试代码如下: 运行 php signal.php  然后CTL+c 或者 kill -SIGINT PID 会导致运行代码跳出死循环去运行pcntl_signal注册的函数,效果就是脚本exit打印“Get signal SIGINT and exi”退出


	
  1. <?php
  2. declare(ticks=1);
  3. pcntl_signal(SIGINT, function(){
  4.    exit("Get signal SIGINT and exit ");
  5. });
  6.  
  7. echo "Ctl + c or run cmd : kill -SIGINT " . posix_getpid(). " " ;
  8.  
  9. while(1){
  10.   $num = 1;
  11. }

 



上一篇:Apache Kafka详解   下一篇:美国是如何减羊毛!

姓 名: *
邮 箱:
内 容: *
验证码: 点击刷新 *   

回到顶部