11個(gè)PHPer必須要了解的編程規(guī)范
本文將討論常用的良好的代碼習(xí)慣,或者稱為代碼規(guī)范,在PHP領(lǐng)域。
1,錯(cuò)誤報(bào)告開(kāi)啟
錯(cuò)誤報(bào)告是在PHP中一個(gè)非常有用的功能,應(yīng)同時(shí)在開(kāi)發(fā)階段啟用。 這可以幫助我們確定我們的代碼中的問(wèn)題。 最常用的功能是“E_ALL”,這有助于我們發(fā)現(xiàn)所有的警告和嚴(yán)重錯(cuò)誤。 必須指出的是,我們把我們的代碼投入上線前,我們應(yīng)該關(guān)閉這個(gè)功能提示,否則會(huì)在瀏覽器上的暴漏所有潛在錯(cuò)誤及警告。
2,使用DRY原則
‘Do not Repeat Yourself',DRY原則指的是不要重復(fù)你的代碼.。 這個(gè)概念是一個(gè)非常有用的編程概念,可硬應(yīng)用在任何編程語(yǔ)言,如Java,C?;騊HP均可以。 使用DRY原則,確保我們?cè)诔绦蛑袥](méi)有冗余的代碼。
違反 DRY 原則的解決方案通常被稱為 WET,指代“write everything twice”,我們寫(xiě)的相同功能的代碼會(huì)出現(xiàn)多次以上,別大家戲稱是喜歡打字。
讓我們看看到下面的代碼:
Listing1:
WET代碼方式:
$mysql = mysql_connect ( 'localhost', 'mysqladmin_uid', 'mysqladmin_pwd' ); mysql_select_db( 'DB_NAME' ) or die( "Sorry !! No database selected!");
下面使用DRY 原則優(yōu)化代碼:
$db_host = ' localhost '; $db_user = ' mysqladmin_uid '; $db_password = ' mysqladmin_pwd '; $db_database = ' DB_NAME '; $mysql = mysql_connect($db_host, $db_user, $db_password); mysql_select_db($db_database);
3,適當(dāng)?shù)氖褂每s進(jìn)及空格
在使用任何一種編程語(yǔ)言編寫(xiě)代碼時(shí),必須確保代碼在需要的地方提供在必要適當(dāng)?shù)目s進(jìn)和足夠的空格。 以增加了代碼的可讀性,用更有效的方式管理代碼。
4,使用有意義和一致的命名標(biāo)準(zhǔn)
正如任何編程語(yǔ)言,PHP的老兵還建議我們遵循有意義的命名標(biāo)準(zhǔn)。 我們有兩個(gè)主要方式在實(shí)現(xiàn)這個(gè)要求:
A.駝峰式
在這種方法中,第一個(gè)字母是小寫(xiě),每一個(gè)單詞的第一個(gè)字母其后以大寫(xiě)。
Listing2:
public class MyClass {
public void methodName(String argName) {
}
}
B.下劃線式
在這種方法中,我們把每?jī)蓚€(gè)詞之間的下劃線(“_”)。 使用這種方法時(shí),代碼可以被修改如下:
Listing3:使用下劃線代碼片段
public class MyClass {
public void method_name(String arg_name) {
}
}
5,避免深層嵌套
使用任何開(kāi)發(fā)語(yǔ)言,多級(jí)嵌套降低了代碼的可讀性。 任何開(kāi)發(fā)者都應(yīng)應(yīng)避免使用深層嵌套。
Listing4:代碼片段具有多級(jí)嵌套
<?php
class MyClass {
public function method_name($arg_name) {
if (is_writable ( $folder )) {
if ($fp = fopen ( $file_location_path, 'w' )) {
if ($stuff = extractSomeConditionalStuff ()) {
if (fwrite ( $fp, $stuff )) {
// ...
} else {
return false;
}
} else {
return false;
}
} else {
return false;
}
} else {
return false;
}
}
}
?>
上面的代碼是一個(gè)簡(jiǎn)單的嵌套代碼。 我們可以看到它是非常困難的,如果塊結(jié)束哪里的身影。 為了更好的可讀性,讓我們修改的代碼:
Listing5:代碼片段,避免多級(jí)嵌套
function method_name (String arg_name) {
// ...
if (! is_writable ( $folder )) {
return false;
}
if (! $fp = fopen ( $file_location_path, 'w' )) {
return false;
}
if (! $stuff = extractSomeConditionalStuff ()) {
return false;
}
if (fwrite ( $fp, $stuff )) {
// ...
} else {
return false;
}
}
6,添加應(yīng)有的注釋
開(kāi)發(fā)中,請(qǐng)確保你的源代碼中有足夠的行內(nèi)注釋。 這是一個(gè)應(yīng)該遵守的標(biāo)準(zhǔn)做法。 這有助于深入分析代碼,因?yàn)橥ǔG闆r下,負(fù)責(zé)編碼的人不會(huì)一直保持不變。 即使同一個(gè)人被要求在代碼中進(jìn)行一些簡(jiǎn)單的修改,行內(nèi)的注釋總是會(huì)有助于理解當(dāng)時(shí)編寫(xiě)代碼是用來(lái)做什么的。 為了在PHP中使用較好的注釋標(biāo)準(zhǔn),建議大家去查看一些標(biāo)準(zhǔn)的PHP文檔包,例如phpDocumentor。
7,不要把PHPINFO()函數(shù)在網(wǎng)站根目錄
phpinfo()函數(shù)是一個(gè)非常重要的功能,應(yīng)小心使用。 使用此功能,任何人都可以看到服務(wù)器環(huán)境的詳細(xì)信息。它最好始終放在
一個(gè)安全位置的文件中使用,一旦開(kāi)發(fā)完成上線后,應(yīng)該刪除這段代碼使用。
8,永遠(yuǎn)不要相信用戶
如果您的應(yīng)用程序涉及任何用戶輸入,務(wù)必要編寫(xiě)安全的代碼以處理這種方式,因?yàn)樗鞣N可能的輸入。 想要避免程序被攻擊注入或者破壞數(shù)據(jù)完整性,一定要驗(yàn)證過(guò)濾數(shù)據(jù)的格式。大家可以看下這篇文章《可怕的代碼注入方式》
9,合理使用緩存機(jī)制
良好的編程方法總是建議使用緩存機(jī)制緩存幫助我們獲得更好的性能。
在PHP的世界,緩存使用來(lái)實(shí)現(xiàn):
Memcached的 —— 一個(gè)在使用小數(shù)據(jù)塊存儲(chǔ)鍵值對(duì)存 儲(chǔ)。
APC —— 可選PHP緩存為開(kāi)放的PHP操作碼緩存
XCache —— 一種快速可靠的PHP操作碼緩存
Zend Cache – API,用于實(shí)現(xiàn)先進(jìn)的高速緩存功能的集合。
eAcclerator – 開(kāi)源的緩存工具
10,避免復(fù)制已有變量
將預(yù)定義變量復(fù)制到具有較小的名字的局部變量不是一個(gè)好的編程習(xí)慣。 這對(duì)應(yīng)用程序的性能產(chǎn)生不利影響。 讓我們來(lái)看看下面的代碼片段:
Listing6:復(fù)制已有變量
$desc = strip_tags($_POST['PHP description']); echo $desc;
上面的代碼的代碼是復(fù)制一個(gè)變量為局部變量不必要的例子。 這是不是一個(gè)好的做法。同樣的效果可以通過(guò)使用下面的代碼來(lái)實(shí)現(xiàn):
echo strip_tags($_POST['PHP description']);
11,使用框架
框架是大量的研究后開(kāi)發(fā)的,因此,他們被證明是問(wèn)題較少。 它們使我們的開(kāi)發(fā)更便捷,因?yàn)樗鼈兲峁┏墒斓慕鉀Q方案。 在PHP中有很多可用的框架。 在開(kāi)發(fā)過(guò)程中,你應(yīng)該利用這些。 其中的一個(gè)框架,被廣泛采用的是MVC或模型視圖控制器。
結(jié)論:
編程規(guī)范指導(dǎo)我們更有效的開(kāi)發(fā)代碼。
遵循編程規(guī)范,確保應(yīng)用程序的更好的性能。
正如在其他編程語(yǔ)言,要想創(chuàng)造出高質(zhì)量的代碼,PHP也需要遵循這種良好的編程規(guī)范。
相關(guān)文章
php中實(shí)現(xiàn)字符串翻轉(zhuǎn)的方法
本文主要介紹了實(shí)現(xiàn)php字符串翻轉(zhuǎn)的方法,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
如何使用Casbin作為ThinkPHP的權(quán)限控制中間件
本文介紹了如何使用Casbin作為ThinkPHP的權(quán)限控制中間件,感興趣的同學(xué),可以參考下,理解其原理。2021-05-05
PHP zlib擴(kuò)展實(shí)現(xiàn)頁(yè)面GZIP壓縮輸出
GZIP(GNU-ZIP)是一種壓縮技術(shù)。經(jīng)過(guò)GZIP壓縮后頁(yè)面大小可以變?yōu)樵瓉?lái)的30%甚至更小。這樣用戶瀏覽的時(shí)候就會(huì)感覺(jué)很爽很愉快!2010-06-06
Linux平臺(tái)PHP5.4設(shè)置FPM線程數(shù)量的方法
這篇文章主要介紹了Linux平臺(tái)PHP5.4設(shè)置FPM線程數(shù)量的方法,較為詳細(xì)的分析了Linux平臺(tái)php5.4設(shè)置FPM的相關(guān)參數(shù)、功能及使用技巧,需要的朋友可以參考下2016-11-11
php strtotime 函數(shù)UNIX時(shí)間戳
int strtotime ( string time [, int now]) 本函數(shù)預(yù)期接受一個(gè)包含英文日期格式的字符串并嘗試將其解析為 UNIX 時(shí)間戳。2009-01-01
PHP curl批處理及多請(qǐng)求并發(fā)實(shí)現(xiàn)方法分析
這篇文章主要介紹了PHP curl批處理及多請(qǐng)求并發(fā)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了php curl并發(fā)請(qǐng)求處理相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-08-08
PHP的Yii框架中YiiBase入口類的擴(kuò)展寫(xiě)法示例
這篇文章主要介紹了PHP的Yii框架中YiiBase入口類的擴(kuò)展寫(xiě)法示例,同時(shí)詳細(xì)講解了import和autoload這兩個(gè)YiiBase中的重要方法,需要的朋友可以參考下2016-03-03

