明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

PHP 高手之路(3)

[摘要]使用str-replace而不是ereg-replace 習(xí)慣使用Perl進(jìn)行編程的程序員更加愿意使用ereg_replace完成字符串替換工作,因?yàn)樵赑HP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的這段代碼證明,使用str_replace 代替 ereg_r...
使用str-replace而不是ereg-replace
  習(xí)慣使用Perl進(jìn)行編程的程序員更加愿意使用ereg_replace完成字符串替換工作,因?yàn)樵赑HP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的這段代碼證明,使用str_replace 代替 ereg_replace將可以大大提高代碼的運(yùn)行速度。
   
測(cè)試str_replace和ereg_replace的運(yùn)行速度

  //這段代碼測(cè)試str_replace的運(yùn)行速度
   

  emphasis; ?>
   
    for ($i=0; $i<1000; $i++) {
  str_replace(i>, b>, $string).
;
  }
  ?>
   
  //這段代碼測(cè)試ereg_replace的運(yùn)行速度
   


   
    for ($i=0; $i<1000; $i++) {
  ereg_replace(<([/]*)i>, <\\1b>, $string).
;
  }
  ?>
   
   


   

  //打印結(jié)果
   

結(jié)論

  使用str_replace的時(shí)間 -
   

  使用ereg_pattern的時(shí)間 -
  運(yùn)行上面的代碼,得到的結(jié)果是:
  使用str_replace的時(shí)間 - 0.089757
  使用ereg_pattern的時(shí)間 - 0.248881
  從運(yùn)行的結(jié)果我們可以看出使用str_replace替代ereg_replace作為字符串替換函數(shù),極大地提高了代碼的運(yùn)行速度。
  3.注意字符串的引用
  PHP和其它很多編程語(yǔ)言一樣,可以使用雙引號(hào)(\"\")來(lái)引用字符串,也可以使用單引號(hào)()。但是在PHP中,如果使用雙引號(hào)來(lái)引用字符串,那么PHP解析器將首先分析字符串中有沒(méi)有對(duì)變量的引用,有變量的話,將對(duì)變量進(jìn)行替換。如果是單引號(hào),則沒(méi)有如此復(fù)雜——直接將單引號(hào)包含起來(lái)的所有字符串直接顯示出來(lái)。顯然,在PHP編程中,如果使用單引號(hào)引用字符串變量要比使用雙引號(hào)快速一些。
  4.在數(shù)據(jù)庫(kù)中避免使用聯(lián)合操作
  比起其它的Web編程語(yǔ)言來(lái)說(shuō),PHP的數(shù)據(jù)庫(kù)功能十分強(qiáng)大。但是在PHP中數(shù)據(jù)庫(kù)的運(yùn)行仍然是一件十分費(fèi)時(shí)費(fèi)力的事情,所以,作為一個(gè)Web程序員,要盡量減少數(shù)據(jù)庫(kù)的查詢操作,同時(shí)應(yīng)該為數(shù)據(jù)庫(kù)建立適當(dāng)?shù)乃饕。另一件值得注意的事情是在用PHP操作數(shù)據(jù)庫(kù)時(shí),盡可能不使用多個(gè)數(shù)據(jù)表的聯(lián)合操作,盡管聯(lián)合操作可以增強(qiáng)數(shù)據(jù)庫(kù)的查詢功能,但是卻大大增加了服務(wù)器的負(fù)擔(dān)。
  為了說(shuō)明這個(gè)問(wèn)題,我們可以看看下面的這個(gè)簡(jiǎn)單的例子。
  我們?cè)跀?shù)據(jù)庫(kù)中創(chuàng)建了兩個(gè)數(shù)據(jù)表foo和big_foo。在數(shù)據(jù)表foo中,只有一個(gè)字段,包含了從1-1000之間的所有自然數(shù)。數(shù)據(jù)表big_foo同樣只有一個(gè)字段,但包含了從1-1,000,000之間的全部自然數(shù)。所以,從大小上說(shuō),big_foo等于foo與它自身進(jìn)行了聯(lián)合操作。
  $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
  從上面操作結(jié)果我們可以發(fā)現(xiàn),對(duì)于兩個(gè)有1000條記錄的數(shù)據(jù)表進(jìn)行聯(lián)合,其速度并不比對(duì)一個(gè)1000000條紀(jì)錄的大型數(shù)據(jù)表單獨(dú)進(jìn)行操作快多少。
  5.注意include與require的區(qū)別
  在PHP變成中,include()與require()的功能相同,但在用法上卻有一些不同,include()是有條件包含函數(shù),而require()則是無(wú)條件包含函數(shù)。例如在下面的一個(gè)例子中,如果變量$somgthing為真,則將包含文件somefile:
  if($something){
  include(\"somefile\");
  }
  但不管$something取何值,下面的代碼將把文件somefile包含進(jìn)文件里:
  if($something){
  require(\"somefile\");
  }
  下面的這個(gè)有趣的例子充分說(shuō)明了這兩個(gè)函數(shù)之間的不同。
  $i = 1;
  while ($i < 3) {
  require(\"somefile.$i\");
  $i++;
  }
  在這段代碼中,每一次循環(huán)的時(shí)候,程序都將把同一個(gè)文件包含進(jìn)去。很顯然這不是程序員的初衷,從代碼中我們可以看出這段代碼希望在每次循環(huán)時(shí),將不同的文件包含進(jìn)來(lái)。如果要完成這個(gè)功能,必須求助函數(shù)include():
  $i = 1;
  while ($i < 3) {
  include(\"somefile.$i\");
  $i++;
  }
  6.注意echo和print的區(qū)別
  PHP中echo和print的功能也基本相同,但是兩者之間也有細(xì)微差別。在PHP代碼中可以把print作為一個(gè)普通函數(shù)來(lái)使用,例如執(zhí)行下面的代碼后變量$res的值將為1。
  $ret = print \"Hello World\";
  這意味著print可用在一些復(fù)雜的表達(dá)式中,而echo則不行。同樣,在代碼中echo語(yǔ)句的運(yùn)行速度要略微快于print語(yǔ)句,因?yàn)閑cho語(yǔ)句不要求返回任何數(shù)值



標(biāo)簽:PHP 高手之路(3)