本文實例講述了php實現的Timer頁面運行時間監測類及其用法,是一款非常實用的PHP類文件。分享給大家供大家參考。具體分析如下:
該php Timer頁面運行時間監測類,可按不同key監測不同的運行時間。
Timer.class.php類文件如下:
<?php
/** Timer class, 計算頁面運行時間,可按不同key計算不同的運行時間
* Date: 2014-02-28
* Author: fdipzone
* Ver: 1.0
*
* Func:
* public start 記錄開始時間
* public end 記錄結束時間
* public getTime 計算運行時間
* pulbic printTime 輸出運行時間
* private getKey 獲取key
* private getMicrotime 獲取microtime
*/
class Timer{ // class start
private $_start = array();
private $_end = array();
private $_default_key = 'Timer';
private $_prefix = 'Timer_';
/** 記錄開始時間
* @param String $key 標記
*/
public function start($key=''){
$flag = $this->getKey($key);
$this->_start[$flag] = $this->getMicrotime();
}
/** 記錄結束時間
* @param String $key 標記
*/
public function end($key=''){
$flag = $this->getKey($key);
$this->_end[$flag] = $this->getMicrotime();
}
/** 計算運行時間
* @param String $key 標記
* @return float
*/
public function getTime($key=''){
$flag = $this->getKey($key);
if(isset($this->_end[$flag]) && isset($this->_start[$flag])){
return (float)($this->_end[$flag] - $this->_start[$flag]);
}else{
return 0;
}
}
/** 輸出頁面運行時間
* @param String $key 標記
* @return String
*/
public function printTime($key=''){
printf("%srun time %f ms\r\n", $key==''? $key : $key.' ', $this->getTime($key)*1000);
}
/** 獲取key
* @param String $key 標記
* @return String
*/
private function getKey($key=''){
if($key==''){
return $this->_default_key;
}else{
return $this->_prefix.$key;
}
}
/** 獲取microtime
*/
private function getMicrotime(){
list($usec, $sec) = explode(' ', microtime());
return (float)$usec + (float)$sec;
}
} // class end
?>
demo示例代碼如下:
<?php
require 'Timer.class.php';
$timer = new Timer();
$timer->start();
$timer->start('program1');
usleep(mt_rand(100000,500000));
$timer->end('program1');
$timer->printTime('program1');
$timer->start('program2');
usleep(mt_rand(100000,500000));
$timer->end('program2');
$timer->printTime('program2');
$timer->end();
$timer->printTime();
?>
demo運行輸出:
program1 run time 163.285971 ms program2 run time 100.347042 ms run time 264.035940 ms
完整實例源碼點擊此處本站下載。
希望本文所述對大家的PHP程序設計有所幫助。
首先
一樓回答有誤,事實上php和網頁完全無關。
“打開網頁”這個操作僅僅就是給服務器發送信息,然後服務器執行php。
php可以直接在shell上作為腳本執行,也可以用網頁啟動後關閉網頁照樣執行。
然後回答樓主的問題
樓主你的要求,可是程序到達24:00這個時間則關閉?
那根本就不需要記錄啟動的時間,只要到達24點就執行關閉即可。
寫一個死循環
<?php
ignore_user_abort(); // 使php可以在後台運行
set_time_limit(0); // 取消php的響應時間
do{
$time=date('h:i');//獲得當前時間
if($time=="24:00")//到達時間則退出循環
break;
sleep(1000); // 每秒運行一次
}while(true);
?>
修改該程序即可達到你要的效果。如果你的要求是,一定要第二天24點才退出,那麼請把date寫成date('Y-M-D h:i')
然後使用split方法拆解計算日期
的確問得很不清楚。
你的出錯原因是引用的文件不存在,這個類無法調用。
我的QQ 42696883