欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用PHP編程說明第2/3頁

 更新時間:2008年10月26日 00:05:42   作者:  
PHP是一門高效的網(wǎng)絡(luò)編程語言,由于它具有編寫靈活、運行快速等優(yōu)點,迅速成為Web程序員的首選語言。前不久的一份權(quán)威調(diào)查表明,現(xiàn)在已經(jīng)有31.6%的網(wǎng)站使用PHP作為主要的服務(wù)器端編程語言。

需要的時候,在程序中簡單地加入下面的一條代碼即可查看程序中的所使用的變量(包括數(shù)組和對象)的類型和值:
echo ss_as_string($my_variable);
使用下面的語句,我們可以直接查看程序中所有的變量的值:
echo ss_as_string($GLOBALS);
3. 控制Log信息的函數(shù)
調(diào)試PHP程序的另外一種重要的方法就是查看Log信息。如果能夠方便地控制Log信息的級別以及Log信息的顯示內(nèi)容,將會給程序調(diào)試帶來更多的便利。下面的幾個函數(shù)可以方便地實現(xiàn)這個功能。
$ss_log_level = 0;
$ss_log_filename = /tmp/ss-log;
$ss_log_levels = array(
NONE => 0,
ERROR => 1,
INFO => 2,
DEBUG => 3);
function ss_log_set_level ($level = ERROR) {
global $ss_log_level;
$ss_log_level = $level;
}
function ss_log ($level, $message) {
global $ss_log_level, $ss-log-filename;
if ($ss_log_levels[$ss_log_level] < $ss_log_levels[$level]) {
// 不顯示Log信息
return false;
}
$fd = fopen($ss_log_filename, "a+");
fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");
fclose($fd);
return true;
}
function ss_log_reset () {
global $ss_log_filename;
@unlink($ss_log_filename);
}
在上面的函數(shù)中,有四個Log級別變量。運行PHP程序時,只有當Log的級別低于預(yù)設(shè)的級別值時,Log信息才可以被記錄和顯示出來。例如,在程序中加入如下的一條語句:
ss_log_set_level(INFO);
那么,運行PHP程序時,只有ERROR和INFO級別的LOG信息才能被記錄和顯示出來,DEBUG級的信息則被忽略了。除此之外,我們還可以設(shè)定顯示的信息內(nèi)容,其語句如下:
ss_log(ERROR, "testing level ERROR");
ss_log(INFO, "testing level INFO");
ss_log(DEBUG, "testing level DEBUG");
你也可以隨時使用下面的語句清空LOG信息:
ss_log_reset();
4.速度測試函數(shù)
為了優(yōu)化代碼,我們需要一種可以測試代碼運行時間的方法,從而來選擇最優(yōu)的代碼。下面的函數(shù)可以測試運行代碼所需的時間:
function ss_timing_start ($name = default) {
global $ss_timing_start_times;
$ss_timing_start_times[$name] = explode( , microtime());
}
function ss_timing_stop ($name = default) {
global $ss_timing_stop_times;
$ss_timing_stop_times[$name] = explode(, microtime());
}
function ss_timing_current ($name = default) {
global $ss_timing_start_times, $ss_timing_stop_times;
if (!isset($ss_timing_start_times[$name])) {
return 0;
}
if (!isset($ss_timing_stop_times[$name])) {
$stop_time = explode(, microtime());
}
else {
$stop_time = $ss_timing_stop_times[$name];
}
$current = $stop_time[1] - $ss_timing_start_times[$name][1];
$current += $stop_time[0] - $ss_timing_start_times[$name][0];
return $current;
}
現(xiàn)在可以輕松地檢查任何一段代碼的執(zhí)行時間了,甚至我們可以同時使用多個計時器,只需在使用上述的幾個函數(shù)時設(shè)定不同的參數(shù)作為計時器的名稱就可以了。
5.調(diào)試和優(yōu)化數(shù)據(jù)庫的操作
對于數(shù)據(jù)庫來說,運行速度是至關(guān)重要的。盡管很多書籍和文章都講授了一些快速運行數(shù)據(jù)庫的方法,但是所有的方法都必須經(jīng)過實踐的檢驗。下面我們將把PHPLib函數(shù)庫中的query()函數(shù)和上面介紹的幾個函數(shù)綜合起來編寫成新的query()函數(shù),和原先的函數(shù)相比,這個函數(shù)增加了運行時間的監(jiān)測功能。
function query($Query_String, $halt_on_error = 1) {
$this->connect();
ss_timing_start();
$this->Query_ID = @mysql_query($Query_String,$this->Link_ID);
ss_timing_stop();
ss_log(INFO, ss_timing_current(). Secs - .$Query_String);
$this->Row = 0;
$this->Errno = mysql_errno();
$this->Error = mysql_error();
if ($halt_on_error && !$this->Query_ID) {
$this->halt("Invalid SQL: ".$Query_String);
}
return $this->Query_ID;
}
二、編寫漂亮的代碼
1.將后臺程序與前端程序分開
在編寫PHP程序時,有些代碼是用來處理一些事務(wù),例如操作數(shù)據(jù)庫、進行數(shù)學運算等,而另外的一些代碼則只是事務(wù)處理的結(jié)果顯示出來,例如一些使用echo語句將結(jié)果以HTML的格式顯示在Web瀏覽器上的PHP代碼以及那些直接嵌入PHP程序的HTML代碼。首先我們應(yīng)該清晰地區(qū)分這兩種代碼,把前者稱為后臺程序,把后者稱為前端程序。
因為PHP是一種嵌入式編程語言,也就是說,所有的PHP代碼都可以嵌入到HTML代碼之中,這為程序的編寫帶來了許多便利之處。但是,“物極必反”,如果在一段較長的程序中將PHP代碼和HTML代碼混合編寫,這將使程序雜亂無章,不利于程序的維護和閱讀。所以我們需要盡可能地將這些程序中混雜于HTML代碼中的PHP代碼移植出來,在專門的文件中將這些代碼封裝成函數(shù),然后在HTML代碼中使用include語句來包含這些文件,在適當?shù)奈恢谜{(diào)用這些函數(shù)即可。
這種做法一方面使HTML代碼和PHP代碼都簡單易讀,另一方面因為HTML代碼需要不斷更新,而這種分離的方法可以確保后臺程序不會被破壞。
同前端程序不同,后臺程序更多追求的是穩(wěn)定、結(jié)構(gòu)化,極少更改,所以應(yīng)該認真地設(shè)計和管理。其實,在設(shè)計臺程序時,投入大量時間是值得的,“現(xiàn)在栽樹,以后乘涼”,在以后的設(shè)計工作中將可以輕松地使用現(xiàn)在編寫的后臺程序。
2.靈活使用包含文件
正如前面所說的那樣,后臺程序應(yīng)當安排在一系列的包含文件中。包含文件可以通過include語句在需要時動態(tài)裝入,也可以在php.ini文件中通過使用auto_prepend_file指令預(yù)先自動裝入。
如果使用后一種方法的話,雖然取得了一勞永逸的好處,但是也有一些缺點值得我們注意。下面的一段代碼向我們展示了解析一個龐大的包含文件需要一定的時間:
require(timing.inc);
ss_timing_start();
include(test.inc);
ss_timing_stop();
echo
.ss_timing_current().

?>
在上面的代碼中,test.inc是一個1000行的包含文件,運行的結(jié)果顯示,解析這個包含文件花費了0.6秒鐘,對于一個大型網(wǎng)站來說,這個速度并不是可以忽略不記的。
使用包含文件的另外一個缺點是:如果一個文件中的一個語句發(fā)生錯誤,將會使整個網(wǎng)站的PHP程序都無法運行。所以使用起來也及其小心。
其實,對包含文件稍做處理,即可以使包含文件只在需要時進行解析。下面的代碼使abc.inc文件只在程序需要時才作解析:
if ( defined( __LIBA_INC) ) return;
define( __LIBA_INC, 1 );
/*
* 代碼...
*/
?>
3.使用面向?qū)ο蟮木幊谭椒?
PHP也是一種面向?qū)ο蟮恼Z言,面向?qū)ο蟮木幊谭椒ㄊ莾?yōu)秀的程序員們非常推崇的一種軟件設(shè)計方法,在PHP編程中可以充分發(fā)揮面向?qū)ο笳Z言的優(yōu)勢,對編程中的對象進行封裝。在前面的代碼中,我們使用了面向?qū)ο蟮姆椒?,例如在管理?shù)據(jù)庫時,我們將query()函數(shù)封裝進數(shù)據(jù)庫類中,這極大地方便了代碼的管理,增加了程序的可讀性。
三、追求程序速度,而不是編程的速度
在網(wǎng)站建設(shè)中,程序運行速度和網(wǎng)頁下載速度都是關(guān)系成敗的重要因素。作為一名Web程序員,應(yīng)該更加注意代碼的運行速度。下面介紹的幾種方法都在不同程度上提高了代碼的運行速度。
1.使用內(nèi)嵌的HTML代碼,而不是PHP的echo語句。
因為PHP是一門嵌入式Web編程語言,可以將HTML代碼和PHP代碼相互嵌入。但是很多程序員擔心在HTML代碼中過多的使用""嵌入PHP代碼會多次調(diào)用PHP解釋器,從而降低了PHP代碼的運行速度,所以寧愿使用PHP的echo語句來輸出HTML代碼,而不直接使用HTML代碼。但事實卻恰恰相反。每一個PHP頁面只調(diào)用一次PHP解釋器來解釋所有的PHP代碼,所以,只在需要時才嵌入PHP代碼,而大多數(shù)的時候直接使用HTML代碼輸入結(jié)果,不但不會降低程序的運行速度,而且因為減少了對echo語句的解析,往往可以提高代碼的運行速度。

相關(guān)文章

最新評論