2.變數除錯函式
php程式的除錯一直是一件讓人頭疼的事,它既不像vb等高階語言那樣有整合的編譯除錯環境,也不想perl那樣可以在linux或者dos環境下直接執行。其實,我們完全可以通過靈活地使用echo語句來完成對php的除錯工作。
下面的幾個函式可以讓你隨時檢視程式中任何變數的型別及其值。
function ss_array_as_string (&$array, $column = 0)
$str .= $var. ==> ;
$str .= ss_as_string($val, $column+1)."
n";
} for ($i = 0; $i < $column; $i++)
return $str.);
} function ss_object_as_string (&$object, $column = 0)
else
global $$var;
$str .= $var. ==> ;
$str .= ss_as_string($$var, column+1)."
n";
} for ($i = 0; $i < $column; $i++)
return $str.);
} }
function ss_as_string (&$thing, $column = 0)
elseif (is_array($thing))
elseif (is_double($thing))
elseif (is_long($thing))
elseif (is_string($thing))
else
} 需要的時候,在程式中簡單地加入下面的一條**即可檢視程式中的所使用的變數(包括陣列和物件)的型別和值:
echo ss_as_string($my_variable);
使用下面的語句,我們可以直接檢視程式中所有的變數的值:
echo ss_as_string($globals);
3. 控制log資訊的函式
除錯php程式的另外一種重要的方法就是檢視log資訊。如果能夠方便地控制log資訊的級別以及log資訊的顯示內容,將會給程式除錯帶來更多的便利。下面的幾個函式可以方便地實現這個功能。
$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)
function ss_log ($level, $message)
$fd = fopen($ss_log_filename, "a+");
fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");
fclose($fd);
return true;
} function ss_log_reset ()
在上面的函式中,有四個log級別變數。執行php程式時,只有當log的級別低於預設的級別值時,log資訊才可以被記錄和顯示出來。例如,在程式中加入如下的一條語句:
ss_log_set_level(info);
那麼,執行php程式時,只有error和info級別的log資訊才能被記錄和顯示出來,debug級的資訊則被忽略了。除此之外,我們還可以設定顯示的資訊內容,其語句如下:
ss_log(error, "testing level error");
ss_log(info, "testing level info");
ss_log(debug, "testing level debug");
你也可以隨時使用下面的語句清空log資訊:
ss_log_reset();
4.速度測試函式
使用str-replace而不是ereg-replace
習慣使用perl進行程式設計的程式設計師更加願意使用ereg_replace完成字串替換工作,因為在php中ereg_replace的用法和perl中模式匹配的用法相近。但是,下面的這段**證明,使用str_replace 代替 ereg_replace將可以大大提高**的執行速度。
測試str_replace和ereg_replace的執行速度
//這段**測試str_replace的執行速度
emphasis; ?>
for ($i=0; $i<1000; $i++)
?>
//這段**測試ereg_replace的執行速度
for ($i=0; $i<1000; $i++)
?>
//列印結果
結論 使用str_replace的時間 -
使用ereg_pattern的時間 -
執行上面的**,得到的結果是:
使用str_replace的時間 - 0.089757
使用ereg_pattern的時間 - 0.248881
從執行的結果我們可以看出使用str_replace替代ereg_replace作為字串替換函式,極大地提高了**的執行速度。
3.注意字串的引用
php和其它很多程式語言一樣,可以使用雙引號("")來引用字串,也可以使用單引號()。但是在php中,如果使用雙引號來引用字串,那麼php解析器將首先分析字串中有沒有對變數的引用,有變數的話,將對變數進行替換。如果是單引號,則沒有如此複雜——直接將單引號包含起來的所有字串直接顯示出來。顯然,在php程式設計中,如果使用單引號引用字串變數要比使用雙引號快速一些。
4.在資料庫中避免使用聯合操作
比起其它的web程式語言來說,php的資料庫功能十分強大。但是在php中資料庫的執行仍然是一件十分費時費力的事情,所以,作為乙個web程式設計師,要儘量減少資料庫的查詢操作,同時應該為資料庫建立適當的索引。另一件值得注意的事情是在用php運算元據庫時,盡可能不使用多個資料表的聯合操作,儘管聯合操作可以增強資料庫的查詢功能,但是卻大大增加了伺服器的負擔。
為了說明這個問題,我們可以看看下面的這個簡單的例子。
我們在資料庫中建立了兩個資料表foo和big_foo。在資料表foo中,只有乙個字段,包含了從1-1000之間的所有自然數。資料表big_foo同樣只有乙個字段,但包含了從1-1,000,000之間的全部自然數。所以,從大小上說,big_foo等於foo與它自身進行了聯合操作。
$db->query("select * from foo");
0.032273 secs
$db->next_record();
0.00048999999999999 secs
$db->query("insert into foo values (null)");
0.019506 secs
$db->query("select * from foo as a, foo as b");
17.280596 secs
$db->query("select * from foo as a, foo as b where a.id > b.id");
14.645251 secs
$db->query("select * from foo as a, foo as b where a.id = b.id");
0.041269 secs
$db->query("select * from big_foo");
25.393672 secs
從上面操作結果我們可以發現,對於兩個有1000條記錄的資料表進行聯合,其速度並不比對乙個1000000條紀錄的大型資料表單獨進行操作快多少。
5.注意include與require的區別
在php變成中,include()與require()的功能相同,但在用法上卻有一些不同,include()是有條件包含函式,而require()則是無條件包含函式。例如在下面的乙個例子中,如果變數$somgthing為真,則將包含檔案somefile:
if($something)
但不管$something取何值,下面的**將把檔案somefile包含進檔案裡:
if($something)
下面的這個有趣的例子充分說明了這兩個函式之間的不同。
$i = 1;
while ($i < 3)
在這段**中,每一次迴圈的時候,程式都將把同乙個檔案包含進去。很顯然這不是程式設計師的初衷,從**中我們可以看出這段**希望在每次迴圈時,將不同的檔案包含進來。如果要完成這個功能,必須求助函式include():
$i = 1;
while ($i < 3)
6.注意echo和print的區別
php中echo和print的功能也基本相同,但是兩者之間也有細微差別。在php**中可以把print作為乙個普通函式來使用,例如執行下面的**後變數$res的值將為1。
$ret = print "hello world";
這意味著print可用在一些複雜的表示式中,而echo則不行。同樣,在**中echo語句的執行速度要略微快於print語句,因為echo語句不要求返回任何數值.
PHP高手之路 2
二 編寫漂亮的 1.將後台程式與前端程式分開 在編寫php程式時,有些 是用來處理一些事務,例如運算元據庫 進行數 算等,而另外的一些 則只是事務處理的結果顯示出來,例如一些使用echo語句將結果以html的格式顯示在web瀏覽器上的php 以及那些直接嵌入php程式的html 首先我們應該清晰地區...
PHP 高手之路(二)
二 編寫漂亮的 1.將後台程式與前端程式分開 在編寫php程式時,有些 是用來處理一些事務,例如運算元據庫 進行數 算等,而另外的一些 則只是事務處理的結果顯示出來,例如一些使用echo語句將結果以html的格式顯示在wwww.cppcns.comeb瀏覽器上的php 以及那些直接嵌入php程式的h...
PHP 高手之路(三)
使用str replace而不是ereg replace n程式設計客棧bsp 習慣使用perl進行程式設計的程式設計師更加願意使用ereg replace完成字串替換工作,因為在php中ereg replace的用法和perl中模式匹配的用法相近。但是,下面的這段 證明,使用str replace...