日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

怎樣成為PHP高手(2)_PHP教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:概述怎樣用新PHP插件實(shí)現(xiàn)MySQL為基礎(chǔ)的事務(wù)
事務(wù)處理支持很長時(shí)間以來一直是大多數(shù)MySQL開發(fā)者的心愿,隨著MySQL 4.0的發(fā)布,這個(gè)心愿最后終于得以實(shí)現(xiàn)。MySQL 4.0后不久,擁有一個(gè)新的MySQL插件的PHP 5.x也發(fā)布了。這個(gè)新插件,MySQL Improved,使得PHP開發(fā)者通過利用本地的PHP函數(shù),獲得了這些新的事

調(diào)試PHP程序的另外一種重要的方法就是查看Log信息。如果能夠方便地控制Log信息的級別以及Log信息的顯示內(nèi)容,將會(huì)給程序調(diào)試帶來更多的便利。下面的幾個(gè)函數(shù)可以方便地實(shí)現(xiàn)這個(gè)功能。

$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ù)中,有四個(gè)Log級別變量。運(yùn)行PHP程序時(shí),只有當(dāng)Log的級別低于預(yù)設(shè)的級別值時(shí),Log信息才可以被記錄和顯示出來。例如,在程序中加入如下的一條語句:

ss_log_set_level(INFO);

那么,運(yùn)行PHP程序時(shí),只有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");

你也可以隨時(shí)使用下面的語句清空LOG信息:

ss_log_reset();

4.速度測試函數(shù)

為了優(yōu)化代碼,我們需要一種可以測試代碼運(yùn)行時(shí)間的方法,從而來選擇最優(yōu)的代碼。下面的函數(shù)可以測試運(yùn)行代碼所需的時(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í)使用多個(gè)計(jì)時(shí)器,只需在使用上述的幾個(gè)函數(shù)時(shí)設(shè)定不同的參數(shù)作為計(jì)時(shí)器的名稱就可以了。

5.調(diào)試和優(yōu)化數(shù)據(jù)庫的操作

對于數(shù)據(jù)庫來說,運(yùn)行速度是至關(guān)重要的。盡管很多書籍和文章都講授了一些快速運(yùn)行數(shù)據(jù)庫的方法,但是所有的方法都必須經(jīng)過實(shí)踐的檢驗(yàn)。下面我們將把PHPLib函數(shù)庫中的query()函數(shù)和上面介紹的幾個(gè)函數(shù)綜合起來編寫成新的query()函數(shù),和原先的函數(shù)相比,這個(gè)函數(shù)增加了運(yùn)行時(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.將后臺(tái)程序與前端程序分開

在編寫PHP程序時(shí),有些代碼是用來處理一些事務(wù),例如操作數(shù)據(jù)庫、進(jìn)行數(shù)學(xué)運(yùn)算等,而另外的一些代碼則只是事務(wù)處理的結(jié)果顯示出來,例如一些使用echo語句將結(jié)果以HTML的格式顯示在Web瀏覽器上的PHP代碼以及那些直接嵌入PHP程序的HTML代碼。首先我們應(yīng)該清晰地區(qū)分這兩種代碼,把前者稱為后臺(tái)程序,把后者稱為前端程序。

因?yàn)镻HP是一種嵌入式編程語言,也就是說,所有的PHP代碼都可以嵌入到HTML代碼之中,這為程序的編寫帶來了許多便利之處。但是,“物極必反”,如果在一段較長的程序中將PHP代碼和HTML代碼混合編寫,這將使程序雜亂無章,不利于程序的維護(hù)和閱讀。所以我們需要盡可能地將這些程序中混雜于HTML代碼中的PHP代碼移植出來,在專門的文件中將這些代碼封裝成函數(shù),然后在HTML代碼中使用include語句來包含這些文件,在適當(dāng)?shù)奈恢谜{(diào)用這些函數(shù)即可。

這種做法一方面使HTML代碼和PHP代碼都簡單易讀,另一方面因?yàn)镠TML代碼需要不斷更新,而這種分離的方法可以確保后臺(tái)程序不會(huì)被破壞。

同前端程序不同,后臺(tái)程序更多追求的是穩(wěn)定、結(jié)構(gòu)化,極少更改,所以應(yīng)該認(rèn)真地設(shè)計(jì)和管理。其實(shí),在設(shè)計(jì)臺(tái)程序時(shí),投入大量時(shí)間是值得的,“現(xiàn)在栽樹,以后乘涼”,在以后的設(shè)計(jì)工作中將可以輕松地使用現(xiàn)在編寫的后臺(tái)程序。

2.靈活使用包含文件

正如前面所說的那樣,后臺(tái)程序應(yīng)當(dāng)安排在一系列的包含文件中。包含文件可以通過include語句在需要時(shí)動(dòng)態(tài)裝入,也可以在php.ini文件中通過使用auto_prepend_file指令預(yù)先自動(dòng)裝入。

如果使用后一種方法的話,雖然取得了一勞永逸的好處,但是也有一些缺點(diǎn)值得我們注意。下面的一段代碼向我們展示了解析一個(gè)龐大的包含文件需要一定的時(shí)間:

require(timing.inc);

ss_timing_start();

include(test.inc);

ss_timing_stop();

echo

.ss_timing_current().

;

?>

在上面的代碼中,test.inc是一個(gè)1000行的包含文件,運(yùn)行的結(jié)果顯示,解析這個(gè)包含文件花費(fèi)了0.6秒鐘,對于一個(gè)大型網(wǎng)站來說,這個(gè)速度并不是可以忽略不記的。

使用包含文件的另外一個(gè)缺點(diǎn)是:如果一個(gè)文件中的一個(gè)語句發(fā)生錯(cuò)誤,將會(huì)使整個(gè)網(wǎng)站的PHP程序都無法運(yùn)行。所以使用起來也及其小心。

其實(shí),對包含文件稍做處理,即可以使包含文件只在需要時(shí)進(jìn)行解析。下面的代碼使abc.inc文件只在程序需要時(shí)才作解析:

if ( defined( __LIBA_INC) ) return;

define( __LIBA_INC, 1 );

/*

* 代碼...

*/

?>

3.使用面向?qū)ο蟮木幊谭椒?/p>

PHP也是一種面向?qū)ο蟮恼Z言,面向?qū)ο蟮木幊谭椒ㄊ莾?yōu)秀的程序員們非常推崇的一種軟件設(shè)計(jì)方法,在PHP編程中可以充分發(fā)揮面向?qū)ο笳Z言的優(yōu)勢,對編程中的對象進(jìn)行封裝。在前面的代碼中,我們使用了面向?qū)ο蟮姆椒�,例如在管理�?shù)據(jù)庫時(shí),我們將query()函數(shù)封裝進(jìn)數(shù)據(jù)庫類中,這極大地方便了代碼的管理,增加了程序的可讀性。

分享:如何在PHP中執(zhí)行系統(tǒng)外部命令
PHP作為一種服務(wù)器端的腳本語言,象編寫簡單,或者是復(fù)雜的動(dòng)態(tài)網(wǎng)頁這樣的任務(wù),它完全能夠勝任。但事情不總是如此,有時(shí)為了實(shí)現(xiàn)某個(gè)功能,必須借助于操作系統(tǒng)的外部程序(或者稱之為命令),這樣可以做到事半功倍。 那么,是否可以在PHP腳本中調(diào)用外部命令呢

來源:模板無憂//所屬分類:PHP教程/更新時(shí)間:2009-06-18
相關(guān)PHP教程