一级日韩免费大片,亚洲一区二区三区高清,性欧美乱妇高清come,久久婷婷国产麻豆91天堂,亚洲av无码a片在线观看

php語(yǔ)言

怎樣才能成為PHP高手?

時(shí)間:2025-03-15 03:34:56 php語(yǔ)言 我要投稿

怎樣才能成為PHP高手?

  PHP是一門(mén)高效的網(wǎng)絡(luò )編程語(yǔ)言,由于它具有編寫(xiě)靈活、運行快速等優(yōu)點(diǎn),迅速成為Web程序員的首選語(yǔ)言。前不久的一份權威調查表明,現在已經(jīng)有31.6%的網(wǎng)站使用PHP作為主要的服務(wù)器端編程語(yǔ)言。 那么怎樣才能成為PHP高手?快來(lái)看看吧。

  要成為一名PHP編程高手并不容易。并不像很多人想象的那樣,只要能夠飛快地編寫(xiě)幾條簡(jiǎn)單的代碼去解決一個(gè)復雜的問(wèn)題就是PHP編程高手了,真正的PHP高手還需要考慮更多的其它問(wèn)題。以下三條準則是一名成熟的PHP程序員在編程中應該首先遵循的準則。

  1.懶惰是金

  2.編寫(xiě)漂亮的代碼

  3.追求程序的速度,而不是編程的速度

  一、懶惰是金

  做一個(gè)懶惰的程序員嗎?這個(gè)想法太奇怪了!因為這個(gè)世界上最忙碌的人可能就是計算機程序員了。但正是因為程序員太忙了,所以才應該在編程時(shí)學(xué)會(huì )偷懶。

  對于一個(gè)程序員來(lái)說(shuō),懶惰的方法有兩種:其一,大膽使用現成的別人的程序代碼,把這些代碼融入到你自己的程序或者項目中去。其二是編寫(xiě)一些有用的代碼建立一個(gè)函數庫,在將來(lái)編寫(xiě)程序時(shí)可以順手拈來(lái),省去了許多重復的勞動(dòng),自然就可以懶惰一點(diǎn)了。

  這兩種偷懶的方法都非常適合PHP程序員了。

  首先,PHP是在自由開(kāi)放的環(huán)境中誕生和成長(cháng)的一門(mén)語(yǔ)言。在世界各地,有成千上萬(wàn)的程序員,他們一直在為PHP的完美而不斷奮斗,他們也愿意和別人分享自己的聰明才智和自己編寫(xiě)的代碼。你每天都可以從一些PHP網(wǎng)站、郵件列表、新聞組發(fā)現大量的優(yōu)秀的程序代碼。這樣說(shuō),我并不是鼓勵你整天等著(zhù)讓別人為你編寫(xiě)代碼,但是你可以“站在偉人的肩膀上”,充分發(fā)揚“拿來(lái)主義”,聰明地應用別人的程序代碼可以節省你大量時(shí)間。其次,在PHP中,你可以方便地建立自己的函數庫,這樣可以在你以后編寫(xiě)程序時(shí)省去很多麻煩。

  下面筆者為大家介紹幾個(gè)通用的函數,這些函數有的來(lái)自網(wǎng)上的一些開(kāi)放源代碼的項目,有的精選自郵件列表。如果你能把它們加入到你自己的函數庫中,遲早你將會(huì )發(fā)現自己受益無(wú)窮。

  1.通用數據庫處理函數

  和其它的CGI函數相比,PHP的優(yōu)點(diǎn)之一是具有很強大的數據庫處理能力。但是,在PHP中,對于不同的數據庫都使用一些特定的函數來(lái)專(zhuān)門(mén)處理,缺少通用的數據庫處理函數。這大大降低了程序代碼的可移植性,這也為初學(xué)編程的朋友帶來(lái)了很多不便。

  在網(wǎng)上,許多程序員都通過(guò)封裝類(lèi)解決了這個(gè)問(wèn)題。他們編寫(xiě)了統一的函數用來(lái)處理任何流行的數據庫——不管是在Linux世界深受歡迎的Mysql還是在Windows平臺上廣泛流行的SqlServer。就筆者個(gè)人來(lái)說(shuō),非常喜歡使用這些函數,因為可以直接使用一些簡(jiǎn)單的諸如"query"、"next_record"之類(lèi)的函數,而不需要考慮數據庫的連接、數據庫句柄這些復雜的東西,更不需要考慮使用的是何種數據庫。

  如果你需要這些函數,你可以通過(guò)訪(fǎng)問(wèn)以下的幾個(gè)網(wǎng)址而得到:

  http://phplib.netuse.de/

  http://phpclasses.UpperDesign.com/browse.html/package/20

  http://phpdb.linuxbox.com/

  2.變量調試函數

  PHP程序的調試一直是一件讓人頭疼的事,它既不像VB等高級語(yǔ)言那樣有集成的編譯調試環(huán)境,也不想Perl那樣可以在Linux或者DOS環(huán)境下直接運行。其實(shí),我們完全可以通過(guò)靈活地使用echo語(yǔ)句來(lái)完成對PHP的調試工作。

  下面的幾個(gè)函數可以讓你隨時(shí)查看程序中任何變量的類(lèi)型及其值。

function ss_array_as_string (&$array, $column = 0) { 
        $str = "Array(n"; 
         while(list($var, $val) = each($array)){ 
          for ($i = 0; $i < $column+1; $i++){ 
           $str .= "&nbsp;&nbsp;&nbsp;&nbsp;"; 
          } 
          $str .= $var. ==> ; 
          $str .= ss_as_string($val, $column+1)." n"; 
         } 
         for ($i = 0; $i < $column; $i++){ 
          $str .= "&nbsp;&nbsp;&nbsp;&nbsp;"; 
         } 
         return $str.); 
        } 
        function ss_object_as_string (&$object, $column = 0) { 
         if (empty($object->classname)) { 
          return "$object"; 
         } 
         else { 
          $str = $object->classname."( n"; 
           while (list(,$var) = each($object->persistent_slots)) { 
            for ($i = 0; $i < $column; $i++){ 
             $str .= "&nbsp;&nbsp;&nbsp;&nbsp;"; 
            } 
            global $$var; 
            $str .= $var. ==> ; 
            $str .= ss_as_string($$var, column+1)." n"; 
           } 
           for ($i = 0; $i < $column; $i++){ 
            $str .= "&nbsp;&nbsp;&nbsp;&nbsp;"; 
           } 
           return $str.); 
         } 
        } 
        function ss_as_string (&$thing, $column = 0) { 
          if (is_object($thing)) { 
           return ss_object_as_string($thing, $column); 
          } 
          elseif (is_array($thing)) { 
           return ss_array_as_string($thing, $column); 
          } 
          elseif (is_double($thing)) { 
           return "Double(".$thing.")"; 
          } 
          elseif (is_long($thing)) { 
           return "Long(".$thing.")"; 
          } 
          elseif (is_string($thing)) { 
           return "String(".$thing.")"; 
          } 
          else { 
           return "Unknown(".$thing.")"; 
          } 
        }

  需要的時(shí)候,在程序中簡(jiǎn)單地加入下面的一條代碼即可查看程序中的所使用的變量(包括數組和對象)的類(lèi)型和值:

echo ss_as_string($my_variable);

  使用下面的語(yǔ)句,我們可以直接查看程序中所有的變量的值:

echo ss_as_string($GLOBALS);

  3. 控制Log信息的函數

  調試PHP程序的另外一種重要的方法就是查看Log信息。如果能夠方便地控制Log信息的級別以及Log信息的顯示內容,將會(huì )給程序調試帶來(lái)更多的便利。下面的幾個(gè)函數可以方便地實(shí)現這個(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); 
       }

  在上面的函數中,有四個(gè)Log級別變量。運行PHP程序時(shí),只有當Log的級別低于預設的級別值時(shí),Log信息才可以被記錄和顯示出來(lái)。例如,在程序中加入如下的一條語(yǔ)句:

  ss_log_set_level(INFO);

  那么,運行PHP程序時(shí),只有ERROR和INFO級別的LOG信息才能被記錄和顯示出來(lái),DEBUG級的信息則被忽略了。除此之外,我們還可以設定顯示的信息內容,其語(yǔ)句如下:

ss_log(ERROR, "testing level ERROR"); 
       ss_log(INFO, "testing level INFO"); 
       ss_log(DEBUG, "testing level DEBUG");

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

  ss_log_reset();

  4.速度測試函數

  為了優(yōu)化代碼,我們需要一種可以測試代碼運行時(shí)間的方法,從而來(lái)選擇最優(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; 
       }

  現在可以輕松地檢查任何一段代碼的執行時(shí)間了,甚至我們可以同時(shí)使用多個(gè)計時(shí)器,只需在使用上述的幾個(gè)函數時(shí)設定不同的參數作為計時(shí)器的名稱(chēng)就可以了。

  5.調試和優(yōu)化數據庫的操作

  對于數據庫來(lái)說(shuō),運行速度是至關(guān)重要的。盡管很多書(shū)籍和文章都講授了一些快速運行數據庫的方法,但是所有的方法都必須經(jīng)過(guò)實(shí)踐的檢驗。下面我們將把PHPLib函數庫中的query()函數和上面介紹的幾個(gè)函數綜合起來(lái)編寫(xiě)成新的query()函數,和原先的函數相比,這個(gè)函數增加了運行時(shí)間的監測功能。

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; 
       }

  二、編寫(xiě)漂亮的代碼

  1.將后臺程序與前端程序分開(kāi)

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

  因為PHP是一種嵌入式編程語(yǔ)言,也就是說(shuō),所有的PHP代碼都可以嵌入到HTML代碼之中,這為程序的編寫(xiě)帶來(lái)了許多便利之處。但是,“物極必反”,如果在一段較長(cháng)的程序中將PHP代碼和HTML代碼混合編寫(xiě),這將使程序雜亂無(wú)章,不利于程序的維護和閱讀。所以我們需要盡可能地將這些程序中混雜于HTML代碼中的PHP代碼移植出來(lái),在專(zhuān)門(mén)的文件中將這些代碼封裝成函數,然后在HTML代碼中使用include語(yǔ)句來(lái)包含這些文件,在適當的位置調用這些函數即可。

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

  同前端程序不同,后臺程序更多追求的是穩定、結構化,極少更改,所以應該認真地設計和管理。其實(shí),在設計臺程序時(shí),投入大量時(shí)間是值得的,“現在栽樹(shù),以后乘涼”,在以后的設計工作中將可以輕松地使用現在編寫(xiě)的后臺程序。

  2.靈活使用包含文件

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

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

require(timing.inc); 
       ss_timing_start(); 
       include(test.inc); 
       ss_timing_stop(); 
       echo 
       .ss_timing_current(). 
       ; 
       ?>

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

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

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

if ( defined( __LIBA_INC) ) return; 
       define( __LIBA_INC, 1 ); 
       /* 
       * 代碼... 
       */ 
       ?>

  3.使用面向對象的編程方法

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

  三、追求程序速度,而不是編程的速度

  在網(wǎng)站建設中,程序運行速度和網(wǎng)頁(yè)下載 速度都是關(guān)系成敗的重要因素。作為一名Web程序員,應該更加注意代碼的運行速度。下面介紹的幾種方法都在不同程度上提高了代碼的運行速度。

  1.使用內嵌的HTML代碼,而不是PHP的echo語(yǔ)句。

  因為PHP是一門(mén)嵌入式Web編程語(yǔ)言,可以將HTML代碼和PHP代碼相互嵌入。但是很多程序員擔心在HTML代碼中過(guò)多的使用""嵌入PHP代碼會(huì )多次調用PHP解釋器,從而降低了PHP代碼的運行速度,所以寧愿使用PHP的echo語(yǔ)句來(lái)輸出HTML代碼,而不直接使用HTML代碼。但事實(shí)卻恰恰相反。每一個(gè)PHP頁(yè)面只調用一次PHP解釋器來(lái)解釋所有的PHP代碼,所以,只在需要時(shí)才嵌入PHP代碼,而大多數的時(shí)候直接使用HTML代碼輸入結果,不但不會(huì )降低程序的運行速度,而且因為減少了對echo語(yǔ)句的解析,往往可以提高代碼的運行速度。

  下面的一段代碼證明了我們的結論。在這段代碼中,我們使用了前面介紹的時(shí)間測試函數。

  使用str-replace而不是ereg-replace

  習慣使用Perl進(jìn)行編程的程序員更加愿意使用ereg_replace完成字符串替換工作,因為在PHP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的這段代碼證明,使用str_replace 代替 ereg_replace將可以大大提高代碼的運行速度。

  測試str_replace和ereg_replace的運行速度

//這段代碼測試str_replace的運行速度 
       
       emphasis; ?> 
       
       for ($i=0; $i<1000; $i++) { 
        str_replace(i>, b>, $string). ; 
       } 
       ?> 
       
       //這段代碼測試ereg_replace的運行速度 
       
       for ($i=0; $i<1000; $i++) { 
        ereg_replace(<([/]*)i>, <1b>, $string). 
       ; 
       } 
       ?> 
       
       //打印結果
       結論 
       
       使用str_replace的時(shí)間 - 
       使用ereg_pattern的時(shí)間 -

  運行上面的代碼,得到的結果是:

  使用str_replace的時(shí)間 - 0.089757

  使用ereg_pattern的時(shí)間 - 0.248881

  從運行的結果我們可以看出使用str_replace替代ereg_replace作為字符串替換函數,極大地提高了代碼的運行速度。

  3.注意字符串的引用

  PHP和其它很多編程語(yǔ)言一樣,可以使用雙引號("")來(lái)引用字符串,也可以使用單引號()。但是在PHP中,如果使用雙引號來(lái)引用字符串,那么PHP解析器將首先分析字符串中有沒(méi)有對變量的引用,有變量的話(huà),將對變量進(jìn)行替換。如果是單引號,則沒(méi)有如此復雜——直接將單引號包含起來(lái)的所有字符串直接顯示出來(lái)。顯然,在PHP編程中,如果使用單引號引用字符串變量要比使用雙引號快速一些。

  4.在數據庫中避免使用聯(lián)合操作

  比起其它的Web編程語(yǔ)言來(lái)說(shuō),PHP的數據庫功能十分強大。但是在PHP中數據庫的運行仍然是一件十分費時(shí)費力的事情,所以,作為一個(gè)Web程序員,要盡量減少數據庫的查詢(xún)操作,同時(shí)應該為數據庫建立適當的索引。另一件值得注意的事情是在用PHP操作數據庫時(shí),盡可能不使用多個(gè)數據表的聯(lián)合操作,盡管聯(lián)合操作可以增強數據庫的查詢(xún)功能,但是卻大大增加了 服務(wù)器的負擔。

  為了說(shuō)明這個(gè)問(wèn)題,我們可以看看下面的這個(gè)簡(jiǎn)單的例子。

  我們在數據庫中創(chuàng )建了兩個(gè)數據表foo和big_foo。在數據表foo中,只有一個(gè)字段,包含了從1-1000之間的所有自然數。數據表big_foo同樣只有一個(gè)字段,但包含了從1-1,000,000之間的全部自然數。所以,從大小上說(shuō),big_foo等于foo與它自身進(jìn)行了聯(lián)合操作。

$db->query("select * from foo"); 
       0.032273 secs 
       $db->next_record(); 
       0.00048999999999999 secs 
       $db->query(" 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

  從上面操作結果我們可以發(fā)現,對于兩個(gè)有1000條記錄的數據表進(jìn)行聯(lián)合,其速度并不比對一個(gè)1000000條紀錄的大型數據表單獨進(jìn)行操作快多少。

  5.注意include與require的區別

  在PHP變成中,include()與require()的功能相同,但在用法上卻有一些不同,include()是有條件包含函數,而require()則是無(wú)條件包含函數。例如在下面的一個(gè)例子中,如果變量$somgthing為真,則將包含文件somefile:

if($something){ 
        include("somefile"); 
       }

  但不管$something取何值,下面的代碼將把文件somefile包含進(jìn)文件里:

if($something){ 
        require("somefile"); 
       }

  下面的這個(gè)有趣的例子充分說(shuō)明了這兩個(gè)函數之間的不同。

$i = 1; 
       while ($i < 3) { 
        require("somefile.$i"); 
        $i++; 
       }

  在這段代碼中,每一次循環(huán)的時(shí)候,程序都將把同一個(gè)文件包含進(jìn)去。很顯然這不是程序員的初衷,從代碼中我們可以看出這段代碼希望在每次循環(huán)時(shí),將不同的文件包含進(jìn)來(lái)。如果要完成這個(gè)功能,必須求助函數include():

$i = 1; 
       while ($i < 3) { 
        include("somefile.$i"); 
        $i++; 
       }

  6.注意echo和print的區別

  PHP中echo和print的功能也基本相同,但是兩者之間也有細微差別。在PHP代碼中可以把print作為一個(gè)普通函數來(lái)使用,例如執行下面的代碼后變量$res的值將為1。

$ret = print "Hello World";

  這意味著(zhù)print可用在一些復雜的表達式中,而echo則不行。同樣,在代碼中echo語(yǔ)句的運行速度要略微快于print語(yǔ)句,因為echo語(yǔ)句不要求返回任何數值。

【怎樣才能成為PHP高手?】相關(guān)文章:

怎樣才能成為PHP高手01-23

怎么成為網(wǎng)絡(luò )技術(shù)高手07-29

如何迅速成為Java高手08-08

成為Java高手的學(xué)習要點(diǎn)匯編06-25

成為JAVA高手的25個(gè)小竅門(mén)07-20

你是否具備成為java高手的條件03-12

如何成為PHP高級程序員02-09

學(xué)會(huì )四招成為Excel函數應用高手04-11

為什么Laravel會(huì )成為最成功的PHP框架03-20

一级日韩免费大片,亚洲一区二区三区高清,性欧美乱妇高清come,久久婷婷国产麻豆91天堂,亚洲av无码a片在线观看