乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      如何調(diào)試PHP程序

       corefashion 2014-03-11

      調(diào)試的定義:通過(guò)一定方法,在程序中找到并減少缺陷的數(shù)量,從而使其能正常工作。
      這里說(shuō)一些如何調(diào)試PHP程序的經(jīng)驗(yàn)。


      一、PHP自帶的調(diào)試功能

      1、自帶的報(bào)錯(cuò)功能

      兩個(gè)名詞:開(kāi)發(fā)環(huán)境是開(kāi)發(fā)人員在進(jìn)行開(kāi)發(fā)和調(diào)試的環(huán)境,生產(chǎn)環(huán)境是最終客戶在用的線上環(huán)境;
      開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境要分開(kāi)設(shè)置報(bào)錯(cuò)功能。

      (1)開(kāi)發(fā)環(huán)境
      開(kāi)發(fā)環(huán)境需要打開(kāi)報(bào)錯(cuò),以下是php.ini的配置項(xiàng)及其說(shuō)明:

      ; This directive sets the error reporting level.
      ; Development Value: E_ALL | E_STRICT (Show all errors, warnings and notices including coding standards.)
      error_reporting = E_ALL | E_STRICT

      ; This directive controls whether or not and where PHP will output errors,
      ; notices and warnings too. Error output is very useful during development.
      ; Development Value: On
      display_errors = On

      這樣你在開(kāi)發(fā)過(guò)程中,能第一時(shí)間發(fā)現(xiàn)錯(cuò)誤。

      即使是一個(gè)低等級(jí)的報(bào)錯(cuò)“Notice: Undefined variable: a in E:\phpspace\test.php on line 14”,但一個(gè)未定義的變量的使用往往暗藏著bug。

      你會(huì)問(wèn),如果我引進(jìn)了開(kāi)源的類庫(kù),他們拋出一堆的低等級(jí)錯(cuò)誤怎么辦?一般代碼質(zhì)量好的類庫(kù),也沒(méi)有“Notice”級(jí)別的報(bào)錯(cuò)的。所以這也是鑒別一個(gè)類庫(kù)質(zhì)量的方法。

      (2)生產(chǎn)環(huán)境

      生產(chǎn)環(huán)境不能直接將錯(cuò)誤輸出,而是記入日志,以下是php.ini的配置項(xiàng)及其說(shuō)明:

      ; It could be very dangerous in production environments.
      ; It's recommended that errors be logged on production servers rather than
      ; having the errors sent to STDOUT.
      display_errors = Off

      ; Besides displaying errors, PHP can also log errors to locations such as a
      ; server-specific log, STDERR, or a location specified by the error_log
      ; directive found below. While errors should not be displayed on productions
      ; servers they should still be monitored and logging is a great way to do that.
      ; Production Value: On
      log_errors = On

      ; Log errors to specified file.
      error_log = /path/to/php_error.log

      當(dāng)然日志寫到文件里只是一個(gè)選擇,還有其他配置可參考手冊(cè)。

      生產(chǎn)環(huán)境是給客戶提供服務(wù)的,你不可能在上面進(jìn)行斷點(diǎn)、打印輸出等操作,所以日志是不錯(cuò)的選擇。

      2、其他一些語(yǔ)言特性、功能的使用

      (1)少用錯(cuò)誤控制運(yùn)算符“@”

      其的作用是,將“@”放置在一個(gè)PHP表達(dá)式之前,該表達(dá)式可能產(chǎn)生的任何錯(cuò)誤信息都被忽略掉。

      如果一個(gè)缺陷發(fā)生在這個(gè)表達(dá)式中,從PHP的輸出中看不到任何錯(cuò)誤,這增加了調(diào)試的難度。所以能不用則不用。

      (2)有些函數(shù)自帶有debug功能

      比如這行代碼:

      $fp = fsockopen("www.example.com", 80, $errno, $errstr, 30);

      開(kāi)發(fā)者調(diào)試時(shí)已經(jīng)確定,$fp為空,連接失敗,是這一行有問(wèn)題,但是為什么連接失敗?

      函數(shù)是php自帶的,無(wú)法進(jìn)行更深入的調(diào)試。所以一般這樣的函數(shù)(主要是網(wǎng)絡(luò)通信類的),會(huì)自己提供調(diào)試參數(shù):$errno和$errstr。你可以加一句:

      if (!$fp) echo "$errstr ($errno)<br />\n";

      就能看到連接失敗的原因了。

      這些函數(shù)有:fsockopen,pfsockopen,stream_socket_server,stream_socket_client 等。

      還有些函數(shù)是調(diào)試一個(gè)功能用的,比如:mysql_errno,socket_last_error,socket_strerror 等。

      這些只需要了解下,碰到能想到用即可。

      二、引進(jìn)調(diào)試工具

      在遇到復(fù)雜問(wèn)題時(shí),可以借助調(diào)試工具。比較成熟的有Xdebug、ZendDebugger。

      以Xdebug為例,它能夠:控制打印輸出的樣式和數(shù)組層級(jí)、堆棧式的追蹤錯(cuò)誤、追蹤函數(shù)調(diào)用、代碼執(zhí)行覆蓋分析、程序的概要分析(Profiling)、遠(yuǎn)程調(diào)試。詳見(jiàn):http:///docs/。

      Xdebug前兩個(gè)功能是對(duì)PHP原有的調(diào)試功能做了改進(jìn),更方便調(diào)試。

      復(fù)雜的問(wèn)題,調(diào)試不出來(lái)的,可能是業(yè)務(wù)上的的問(wèn)題,下面也有說(shuō)業(yè)務(wù)邏輯的調(diào)試。

      三、調(diào)試業(yè)務(wù)邏輯錯(cuò)誤

      當(dāng)PHP腳本跑起來(lái),沒(méi)有任何錯(cuò)誤,只能說(shuō)它沒(méi)有語(yǔ)法上的錯(cuò)誤,但是不能說(shuō)明它業(yè)務(wù)邏輯上沒(méi)錯(cuò)誤。

      很多業(yè)務(wù)邏輯的錯(cuò)誤并不會(huì)反映在語(yǔ)法錯(cuò)誤上,但調(diào)試的思路和PHP自帶調(diào)試功能差不多。

      下面是一些方法。

      1、最基本的調(diào)試方法

      先確定兩個(gè)東西:程序預(yù)期的結(jié)果、程序現(xiàn)在的不符合預(yù)期的結(jié)果;
      尋找與兩種結(jié)果相關(guān)的代碼片段;
      閱讀這些代碼片段,嘗試以“肉眼”找出錯(cuò)誤;
      找不出,則需要輸出一些關(guān)鍵變量,通過(guò)檢查它們的值是否正確來(lái)判斷是哪里發(fā)生了錯(cuò)誤;
      若干次嘗試,最終你可以確定錯(cuò)誤發(fā)生在哪個(gè)點(diǎn)。

      你也可以借助Xdebug等工具,查看變量值的變化,或者設(shè)置斷點(diǎn)進(jìn)行調(diào)試。

      2、記錄運(yùn)行日志

      有些復(fù)雜或特殊的業(yè)務(wù),用上面的方法不合適,比如:一個(gè)不能被打斷的后臺(tái)運(yùn)行腳本。這些情況下記錄運(yùn)行日志比較合適。

      記日志的點(diǎn)要有所選擇,除了業(yè)務(wù)上比較重要的點(diǎn),通常容易出錯(cuò)的地方有:網(wǎng)絡(luò)連接和通信、系統(tǒng)權(quán)限問(wèn)題等。

      3、單元測(cè)試

      以代碼測(cè)試代碼,而不是像第一點(diǎn)一樣調(diào)試完會(huì)把測(cè)試代碼丟掉。以測(cè)試驅(qū)動(dòng)開(kāi)發(fā)。

      這個(gè)話題比較大,但適合放這里提一下。有興趣的同學(xué)可以去了解。

      四、調(diào)試非功能性的錯(cuò)誤

      非功能性錯(cuò)誤,比如:內(nèi)存溢出導(dǎo)致程序掛掉了、效率有問(wèn)題導(dǎo)致程序非常慢、死循環(huán)了等等。

      這些問(wèn)題,用“肉眼”檢查代碼效率太低了。

      所以可以借助調(diào)試工具做程序的概要分析(Profiling),從中檢查出程序的瓶頸所在。


        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多