PHP高手之路

2021-09-30 02:19:28 字數 4654 閱讀 5546

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...