日期:2010-09-06  浏览次数:20538 次

Aiyiweb.Com提示:如果您在编写 PHP 代码的过程中养成本文讨论的良好习惯,您将能够构建易读、易理解、易维护的代码。使用这种方式构建的易维护代码将降低调试、修复和扩展代码所面临的风险。

依据具体的情况,普通的开发人员往往比优秀的开发人员的效率低 10%~20%。优秀的开发人员的效率更高,由于他们拥有丰富的经验和良好的编程习惯。不良的编程习惯将会影响到效率。本文通过展现一些良好的编程习惯,协助您成为更优秀的程序员。

这些良好的编程习惯不只能提高效率,还能让您编写出在使用程序的整个生命周期中易于维护的代码。编写出来的代码可能需求大量的维护;使用程序的维护是一笔很 大的开支。养成良好的编程习惯能够提高设计质量(比如模块化),从而使代码愈加容易理解,因此维护就愈加容易,同时也降低维护成本。

不良的编程习惯会形成代码缺陷,使其难以维护和修正,并且很可能在修正时又引入其他缺陷。以下是 5 个良好的编程习惯,能够协助 PHP 代码避免这些缺陷:

◆使用良好的命名。

◆分成更小的部分。

◆为代码添加注释。

◆处理错误条件。

◆切忌使用复制粘贴。

下面将详细引见这些习惯:

使用良好的命名

使用良好的命名是最重要的编程习惯,由于描述性强的名称让代码愈加容易阅读和理解。代码能否好理解取决于能否能在未来维护它。即便代码不带有注释,如果它很容易理解,将大大方便日后的更改。这个习惯的目标是让您编写的代码像书本一样容易阅读和理解。

不良习惯:含糊的或无意义的名称

清单 1 中的代码包含过短的变量名、难以辨认的缩写词,并且方法名不能反映该方法的功用。如果方法名给人的感觉是它应该做这件事情,而实际中它却做另外的事情,这将带来严重的问题,由于它会误导人。

清单 1. 不良习惯:含糊的或无意义的名称

<?php
function getNBDay($d)
{
switch($d) {
case 5:
case 6:
case 7:
return 1;
default:
return ($d + 1);
}
}
$day = 5;
$nextDay = getNBDay($day);
echo (”Next day is: ” . $nextDay . “n”);
?>

良好习惯:说明性强并且简约的名称

清单 2 中的代码体现了良好的编程习惯。新的方法名具有很强的说明性,反映了方法的用途。同样,更改后的变量名也更具说明性。独一的保持最短的变量是 $i,在本清单中,它是一个循环变量。虽然很多人不赞同使用过短的名称,但在循环变量中使用还是可以接受的(甚至有好处),由于它明确表明了代码的功用。

清单 2. 良好习惯:说明性强并且简约的名称

<?php
define (’MONDAY’, 1);
define (’TUESDAY’, 2);
define (’WEDNESDAY’, 3);
define (’THURSDAY’, 4);
define (’FRIDAY’, 5);
define (’SATURDAY’, 6);
define (’SUNDAY’, 7);
/*
*
* @param $dayOfWeek
* @return int Day of week, with 1 being Monday and so on.
*/
function findNextBusinessDay($dayOfWeek)
{
$nextBusinessDay = $dayOfWeek;
switch($dayOfWeek) {
case FRIDAY:
case SATURDAY:
case SUNDAY:
$nextBusinessDay = MONDAY;
break;
default:
$nextBusinessDay += 1;
break;
}
return $nextBusinessDay;
}
$day = FRIDAY;
$nextBusDay = findNextBusinessDay($day);
echo (”Next day is:” . $nextBusDay . “n”);
?>

我们鼓励您将大的条件拆分为一个方法,然后用能够描述该条件的名字命名方法。这个技巧能够提高代码的可读性,并且能够将条件具体化,使之能够被提取甚至重用。如果条件发生变化,更新方法也很容易。由于方法拥有一个有意义的名字,所以它能反映代码的用途,让代码更容易阅读。