国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > PHP > 正文

獲取php頁(yè)面執(zhí)行時(shí)間,數(shù)據(jù)庫(kù)讀寫次數(shù),函數(shù)調(diào)用次數(shù)等(THINKphp)

2020-03-22 18:17:06
字體:
供稿:網(wǎng)友
PHP 獲取html' target='_blank'>php頁(yè)面執(zhí)行時(shí)間,數(shù)據(jù)庫(kù)讀寫次數(shù),函數(shù)調(diào)用次數(shù)等(THINKphp)
THINKphp里面有調(diào)試運(yùn)行狀態(tài)的效果:

Process:0.2463s (Load:0.0003s Init:0.0010s Exec:0.1095s Template:0.1355s )|DB:13 queries 0 writes| Cache:2 gets,0 writes|UseMem:415 kb|LoadFile:20|CallFun:63,1370

代表的含義:

運(yùn)行信息: 整體執(zhí)行時(shí)間0.2463s ( 加載:0.0003s 初始化:0.0010s 執(zhí)行:0.1095s 模板:0.1355s ) | 數(shù)據(jù)庫(kù) :13次讀操作 0次寫操作 | 緩存:2次讀取,0次寫入 | 使用內(nèi)存:415 kb | 加載文件:20 | 函數(shù)調(diào)用:63(自定義),1370(內(nèi)置)

下面來分析一下這些數(shù)據(jù)是怎么獲取到的?

PHP獲取頁(yè)面執(zhí)行時(shí)間:
復(fù)制代碼 代碼如下:
/**
* 得到當(dāng)前時(shí)間
*/
function getMicrotime() {

list ($usec, $sec) = explode(" ", microtime());
return ((float) $usec + (float) $sec);
}


使用:上面的方法可以獲取當(dāng)前時(shí)間,計(jì)算頁(yè)面執(zhí)行時(shí)間可以在程序開頭和結(jié)尾出分別執(zhí)行該方法,最后時(shí)間差就是頁(yè)面執(zhí)行的時(shí)間,原理很簡(jiǎn)單。

獲取數(shù)據(jù)庫(kù)讀寫次數(shù)

在數(shù)據(jù)庫(kù)插入和讀取的時(shí)候設(shè)置一個(gè)全局變量,每次執(zhí)行成功一次$i++一次, ,這是tp里面db類的方法,而N的方法是:自動(dòng)累計(jì)的一個(gè)方法。

同理緩存也是這樣計(jì)算出來的

內(nèi)存的開銷
memory_get_usage可以獲取當(dāng)前內(nèi)存的消耗量,可以在程序開始和結(jié)尾分別調(diào)用,差值就是內(nèi)存的開銷

加載文件的數(shù)量
get_included_files:Gets the names of all files that have been included using include, include_once, require or require_once.

也就是可以獲取到所有的include,require的文件數(shù),返回引入文件的數(shù)組:

網(wǎng)址例子":

復(fù)制代碼 代碼如下:
?php
// This file is abc.php

include 'test1.php';
include_once 'test2.php';
require 'test3.php';
require_once 'test4.php';

$included_files = get_included_files();

foreach ($included_files as $filename) {
echo "$filenamen";
}
?


返回的結(jié)果是:

abc.php
test1.php
test2.php
test3.php
test4.php

函數(shù)調(diào)用方法
第一個(gè)看這個(gè),感覺是在每個(gè)方法里面調(diào)用時(shí)自動(dòng)+1.但是感覺不大可能,貌似這個(gè)每個(gè)方法里寫不靠譜,這群里討論半天,最后發(fā)現(xiàn)php的一個(gè)函數(shù):

get_defined_functions返回引入PHP文件的所有方法的array格式,包括自定義的,內(nèi)置的。

引入網(wǎng)址的一個(gè)例子:

復(fù)制代碼 代碼如下:
?php
function myrow($id, $data)
{
return " tr th $id /th td $data /td /tr
}
$arr = get_defined_functions();
print_r($arr);
?


結(jié)果是:

復(fù)制代碼 代碼如下:
Array
(
[internal] = Array
(
[0] = zend_version
[1] = func_num_args
[2] = func_get_arg
[3] = func_get_args
[4] = strlen
[5] = strcmp
[6] = strncmp
...
[750] = bcscale
[751] = bccomp
)

[user] = Array
(
[0] = myrow
)
)


user為自定義方法,internal為內(nèi)置方法數(shù)組。

引申:

get_defined_constants 獲取定義所有常量的數(shù)組
get_defined_functions 獲取定義所有函數(shù)的數(shù)組
get_defined_vars 獲取定義所有變量的數(shù)組
get_declared_classes 返回已經(jīng)定義的類的數(shù)組PHP教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 来宾市| 荣成市| 屏东县| 承德县| 宜兰市| 托里县| 乌恰县| 潮州市| 伊宁县| 遂昌县| 精河县| 香格里拉县| 门源| 宜兰市| 灵山县| 佛山市| 嵊州市| 社会| 西畴县| 筠连县| 台州市| 凭祥市| 城步| 宜黄县| 翁源县| 子长县| 临安市| 陆川县| 镇平县| 九江市| 讷河市| 襄汾县| 综艺| 新平| 尼玛县| 东光县| 阳原县| 巨野县| 武穴市| 丹东市| 五大连池市|