当前位置:Gxlcms > PHP教程 > php记录程序执行时间microtime

php记录程序执行时间microtime

时间:2021-07-01 10:21:17 帮助过:6人阅读

  1. /**
  2. * 记录程序程序时间---只能记录连续的调用改函数
  3. * @param
  4. $time_key
  5. 记录的key,多次执行可以指定同一个key
  6. * @return
  7. none
  8. 没有返回值,直接获取全局变量$time_arr,如果是在方法中调用需要先global一次
  9. **/
  10. function showExecuTime($time_key = '') {
  11. global $time_arr,$time_start,$time_end,$time_num;
  12. $time_now = microtime(true);
  13. if ( !$time_num ) {
  14. $time_num = 0;
  15. }
  16. $time_num++;
  17. if ( $time_num%2 == 1 ) {
  18. $time_start = $time_now;
  19. } else {
  20. $time_end = $time_now;
  21. }
  22. if ( $time_num %2 == 0 && $time_start && $time_end ) {
  23. $time = $time_end - $time_start;
  24. if ( $time_key ) {
  25. $time_arr[$time_key] += $time;
  26. } else {
  27. $time_arr[] = $time;
  28. }
  29. $time_arr['total'] += $time;
  30. }
  31. }
  32. /**
  33. * 记录程序程序时间---可以多次交叉的调用
  34. * @param
  35. $time_key
  36. 记录的key,多次执行可以指定同一个key
  37. * @return
  38. none
  39. 没有返回值,直接获取全局变量$time_arr,如果是在方法中调用需要先global一次
  40. **/
  41. function showExecuTime($time_key = '') {
  42. global $time_arr,$time_key_arr,$time_num;
  43. $time_now = microtime(true);
  44. if ( !$time_key ) {
  45. if ( !$time_num ) {
  46. $time_num = 0;
  47. }
  48. $time_num++;
  49. $time_key = floor(($time_num+1)/2) - 1;
  50. }
  51. // 记录本次是开始时间还是结束时间
  52. if ( !isset($time_key_arr[$time_key])) {
  53. $time_key_arr[$time_key]['num'] = 0;
  54. }
  55. $time_key_arr[$time_key]['num']++;
  56. if ( $time_key_arr[$time_key]['num']%2 == 1 ) {
  57. $time_key_arr[$time_key]['time_start'] = $time_now;
  58. } else {
  59. $time_key_arr[$time_key]['time_end'] = $time_now;
  60. }
  61. // 如果连续记录2次,计算结果
  62. if ( $time_key_arr[$time_key]['num'] %2 == 0 && $time_key_arr[$time_key]['time_start'] && $time_key_arr[$time_key]['time_end'] ) {
  63. $time = $time_key_arr[$time_key]['time_end'] - $time_key_arr[$time_key]['time_start'];
  64. $time_arr[$time_key] += $time;
  65. $time_arr['total'] += $time;
  66. }
  67. }
  68. showExecuTime('all');
  69. showExecuTime();
  70. sleep(1);
  71. showExecuTime('all');//////
  72. sleep(1);
  73. showExecuTime();
  74. sleep(1);
  75. showExecuTime();
  76. sleep(1);
  77. showExecuTime();
  78. showExecuTime('a');
  79. sleep(1);
  80. showExecuTime('a');
  81. // showExecuTime('all');//////
  82. print_r($time_arr);
  83. print_r($time_key_arr);

版权声明:本文为博主原创文章,未经博主允许不得转载。

以上就介绍了php记录程序执行时间microtime,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

人气教程排行