成都網(wǎng)站建設(shè)分享一些pHp開發(fā)中的tips

2023-12-07    分類: 網(wǎng)站建設(shè)

以下這些tips,是我在實際工作中慢慢形成的,有些可能是不正確的,有些出于個人習(xí)慣,所以,千萬不要把以下這些條當(dāng)成什么標(biāo)準(zhǔn),其中可能隱藏著天大的bug,代碼可能正在病態(tài)的運行中,SO!請一定仔細(xì)的看過后想想,這么做的好處是什么?會產(chǎn)生怎樣的負(fù)面影響? 有問題特別歡迎你來和我討論。 這就是我寫這篇文字的目的,希望能和大家多多交流,也希望不斷完善自己,同時又能給大家一些幫助。

開發(fā)習(xí)慣和pHp代碼:

1、準(zhǔn)確的理解各種概念?,F(xiàn)在的新東西層出不窮,望文生義和一知半解對開發(fā)工作有害無益;//比如我就碰到有人理解松散耦合(這個東西不新)的概念居然是要求代碼不要有空行,否則你的程序就是“太松散”了

2、代碼美觀,適當(dāng)?shù)目招?、縮進(jìn),空格,這樣能更容易理解代碼段的意思;

3、一定要寫注釋,而且要恰當(dāng)?shù)淖⑨?,要不然后面的維護(hù)工作或者接手代碼的人會痛哭不已;

4、靜態(tài)方法、類訪問權(quán)限、接口、抽象類應(yīng)該綜合起來使用,發(fā)揮各自特點;

5、不要復(fù)制粘貼,即使是要用到現(xiàn)成的代碼,也要一行一行的審閱后,再加入到新項目,因為經(jīng)驗告訴我們,這太容易出錯了,對于使用開源類這種大段代碼更需要;

6、變量都要初始化;

7、不要只處理error,而忽略warning和notice,這可能會導(dǎo)致日后的莫名其妙的問題,項目在開發(fā)狀態(tài)下應(yīng)該是error_reporting( E_ALL  ^  E_NOTICE ),等到發(fā)布的外網(wǎng)生產(chǎn)環(huán)境時,應(yīng)關(guān)閉所有錯誤報告display_errors=Off,error_reporting(0)

8、記錄一些必要的錯誤日志,比如寫文件失敗、寫memcache失敗,socket連接失敗、讀寫數(shù)據(jù)庫失敗,日志能夠幫助出現(xiàn)問題時的快速定位,外部生產(chǎn)環(huán)境我個人是強烈建議關(guān)閉所有錯誤報告的;

9、用try、catch捕獲異常,對代碼的健壯有幫助,常常在ApI接口中碰到,這樣子顯得友好多了;

10、雙引號中出現(xiàn)的變量建議加上大括號,至于是”${nider}at gmail.com”還是”{$tom}at zendstudio.net”看個人習(xí)慣,我更喜歡后面一種;

11、盡量少的if else嵌套層數(shù),也許你要表達(dá)一個非常復(fù)雜的邏輯算法,但這樣做至少能讓代碼邏輯更清晰

12、多閱讀網(wǎng)上開源項目的優(yōu)秀代碼(不是優(yōu)秀項目的開源代碼),吸取其中值得借鑒的地方

13、語言包用sprintf的格式化來做是多么愜意的一件事??!

14、寫緩存并不總是要先serialize一次的

15、AJAX傳數(shù)據(jù)的時候,不要將數(shù)據(jù)庫查出的數(shù)組直接json_encode后傳給客戶端,這樣做不僅有一定的安全風(fēng)險(字段名暴露),而且一些不需要的數(shù)據(jù)被傳出浪費帶寬,這條同樣適用于ApI接口

16、要記得處理魔術(shù)變量,我的方法是直接關(guān)閉,當(dāng)然也可以獲取開關(guān)狀態(tài)來避免傳輸數(shù)據(jù)被處理兩次的問題

17、用$GLObALS[\'var\']代替global $var

18、不能輕易的die掉程序,尤其是在方法內(nèi)部

19、require、require_once、include、include_once有著略微不同的應(yīng)用場景

20、為了大限度的使得寫入緩存成功,可以結(jié)合重試次數(shù)+usleep,我一般重試3次,還不行那就記下一條log了

21、pHp的常量是個非常好的東西,很多開源項目中用一整個文件來定義要用到的常量

22、盡可能的使用絕對路徑尋找文件

23、autoload是個很靈活的東西

24、最好用上set_error_handler和set_exception_handler,那顯得你的項目更完美

25、pHp的引用類型是很高效的,在進(jìn)行復(fù)雜運算時建議使用

26、@符號抑制錯誤是很耗性能的,因此盡可能的找到替代方案

MYSQL部分:

1、SQL語句用雙引號,其中的值都用單引號,例如”INSERT INTO gril SET money=’{$iMaxMoney}’,age=’18′”

2、用mysqli擴展代替mysql擴展

2、用mysqli_real_escape_string和mysqli_escape_string處理傳出sql語句中的變量

3、用mysqli_set_charset(mysqli->set_charset)代替 query “SET NAMES”

4、聯(lián)合查詢(JOIN)之前,考慮下各個表的數(shù)據(jù)量,不合適的話應(yīng)該分開查,尤其是有緩存可用的時候

5、很多地方需要記錄發(fā)生時間,但不是每一個表都需要,同樣,不是每一個表都需要一個自增量作主鍵

6、很多時候為integer類型加上unsigned是很好的

7、INERT DELEYED、INSERT IGNORE、SELECT DISTINCT…這種語句通常有意想不到的好效果

8、varchar類型并不是不能超過255長度,而是超過了255,這個字段就不能建立索引了,所以,看你的實際需要了

網(wǎng)站標(biāo)題:成都網(wǎng)站建設(shè)分享一些pHp開發(fā)中的tips
標(biāo)題URL:http://www.muchs.cn/news5/299805.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT定制網(wǎng)站、品牌網(wǎng)站制作、網(wǎng)頁設(shè)計公司、網(wǎng)站策劃動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計