首页 php教程 php手册 PHP实例说明编写PHP代码的5个好习惯

PHP实例说明编写PHP代码的5个好习惯

Jun 21, 2016 am 08:56 AM
gt messages quot the

5个PHP编程的好习惯

有些人问,优秀程序员和大牛有什么区别,大概有10到20种吧。因为大牛有很好的编程习惯和丰富的经验,所以他们非常的高效。如果不好的编程习惯出现在你的代码里,你的代码效率就会降低。本文阐述一些好的编程习惯,他们可以让你成为更好的程序员。

这些习惯能让你的代码在高效运行的同时提高可维护性。你写代码的时候,可能大部分时间都浪费在维护上了,程序的维护代价很高。培养良好的编程习惯,如模块化设计,可以让你的代码可读性更好,从而容易维护。

代码中的问题往往伴随着不良的编程习惯,而且后者会导致代码不好修改并可能出现新的缺陷。下面有五个好的编程习惯,将帮你避免这些陷阱:

  1. 使用友好的命名方式。
  2. 使用更精悍短小的代码。
  3. 注释你的代码。
  4. 编写异常处理。
  5. 永远,永远不要复制粘贴.(玉米:我深深的同意这一点)

下面的章节将解释这些习惯。

良好的命名方式是最重要的编程习惯,因为好的命名会让代码易懂,好懂。代码的可读性决定它的可维护性。即使你在代码没有写注释,如果它可读性好的话,它也修改起来也会简单。你应该在练习开时就使用良好的命名方式,让你的代码像一本书一样。

例1包含一个过短的变量名,写出这样的代码非常不好弄懂,而且函数名也没有清晰的描述出这个方法是做什么的。函数名表示了函数的功能,如果它却是做别的用途的,那就会误导别人。

<?<font color="#335533">php</font><br/><br/>function getNBDay($d)<br/>{<br/>    switch($d) {<br/>        case 5:<br/>        case 6:<br/>        case 7:<br/>            return 1;<br/>        default:<br/>            return ($d + 1);<br/>    }<br/>}<br/><br/>$day = 5;<br/><br/>$nextDay = getNBDay($day);<br/><br/>echo ("Next day is: " . $nextDay . "\n");<br/><br/>?><br/>
登录后复制

例2则给出了使用良好命名方式的代码。重新命名函数是为了更好的反映它们的功能。变量也重新命名为描述性的。只有一个在循环中的$i还使用短的变量名。尽管有些人不同意,短变量名在循环中是请允许的——甚至更好些,因为它们清晰的起到了指针的功能。

<?<font color="#335533">php</font><br/><br/>define ('MONDAY', 1);<br/>define ('TUESDAY', 2);<br/>define ('WEDNESDAY', 3);<br/>define ('THURSDAY', 4);<br/>define ('FRIDAY', 5);<br/>define ('SATURDAY', 6);<br/>define ('SUNDAY', 7);<br/><br/>/*<br/> *<br/> * @param $dayOfWeek<br/> * @return int Day of week, with 1 being Monday and so on.<br/> */<br/>function findNextBusinessDay($dayOfWeek)<br/>{<br/>    $nextBusinessDay = $dayOfWeek;<br/><br/>    switch($dayOfWeek) {<br/>        case FRIDAY:<br/>        case SATURDAY:<br/>        case SUNDAY:<br/>            $nextBusinessDay = MONDAY;<br/>            break;<br/>        default:<br/>            $nextBusinessDay += 1;<br/>            break;<br/>    }<br/><br/>    return $nextBusinessDay;<br/>}<br/><br/>$day = FRIDAY;<br/><br/>$nextBusDay = findNextBusinessDay($day);<br/><br/>echo ("Next day is:" . $nextBusDay . "\n");<br/><br/>?><br/>
登录后复制

我鼓励你在函数中分隔长的条件给函数命名,以便于描述这个条件。(玉米:这句话啥意思?5555)这个技巧会让你的代码容易阅读和扩展,因此它可以被抽象复用。如果条件发生了改变,这样也会很容易更新函数 .由于方法有一个见名知义的名字,化码就不会失去它本来的意思或者变得难以理解。

使用更少的代码

编写代码、解决问题是一种容易的事情。当你解决一个正在发生的问题,编呀编,写呀写,你的方法越来越长。只要你回头使用更少的代码来重构,就是过了很久也没什么问题。

重构是个好主意,但你应该养成第一次就写出更短小精悍代码的习惯。在一个窗口上(玉米:不用翻页)就能看全的短小函数更容易理解。 要是一个函数长出了窗口,就很难理解了,因为你不能快速的从头到脚的浏览整个代码。

当构思一个方法的时候,你还应该养成一个让它们只做一件事情的习惯。以下因素写代码时应常注意。第一,只做一件事情的函数更易于复用。第二,这样的函数测试更方便。第三,这样的函数好读易懂方便改——如果必要的话——让它们尽可能的简单吧。

坏习惯:过长的函数(很多时候)

例三是过长函数的表现。它不知道自己要做什么。它做太多的事情,所以没有集成化。它更难以理解,不好Debug和测试。它遍历文件建立列表,它给对象赋值,它做一些计算,……它耕田,它浇水,甚至做更多事情。(^_^)

例三. 坏习惯:过长函数

<?<font color="#335533">php</font><br/><br/>function writeRssFeed($user)<br/>{<br/>    // Get the DB connection information<br/><br/><br/>    // look up the user's preferences...<br/>    $link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password')<br/>        OR die(mysql_error());<br/><br/>    // Query<br/>    $perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<br/>            mysql_real_escape_string($user));<br/><br/>    $result = mysql_query($query, $link);<br/><br/>    $max_stories = 25; // default it to 25;<br/><br/>    if ($row = mysql_fetch_assoc($result)) {<br/>        $max_stories = $row['max_stories'];<br/>    }<br/><br/>    // go get my data<br/>    $perfsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<br/>            mysql_real_escape_string());<br/><br/>    $result = mysql_query($query, $link); <br/><br/><br/>    $feed = "<rss version=\"2.0\">" .<br/>        "<channel>" .<br/>        "<title>My Great Feed</title>" .<br/>        "<link>http://www.example.com/feed.xml</link>" .<br/>        "<description>The best feed in the world</description>" .<br/>        "<language>en-us</language>" .<br/>        "<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<br/>        "<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<br/>        "<docs>http://www.example.com/rss</docs>" .<br/>        "<generator>MyFeed Generator</generator>" .<br/>        "<managingEditor>editor@example.com</managingEditor>" .<br/>        "<webMaster>webmaster@example.com</webMaster>" .<br/>        "<ttl>5</ttl>";<br/><br/>        // build the feed...<br/>        while ($row = mysql_fetch_assoc($result)) {<br/>            $title = $row['title'];<br/>            $link = $row['link'];<br/>            $description = $row['description'];<br/>            $date = $row['date'];<br/>            $guid = $row['guid'];<br/><br/>            $feed .= "<item>";<br/>            $feed .= "<title>" . $title . "</title>";<br/>            $feed .= "<link>" . $link . "</link>";<br/>            $feed .= "<description> " . $description . "</description>";<br/>            $feed .= "<pubDate>" . $date . "</pubDate>";<br/>            $feed .= "<guid>" . $guid . "</guid>";<br/>            $feed .= "</item>";<br/>        }<br/><br/>        $feed .= "</rss";<br/><br/>        // write the feed out to the server...<br/>        echo($feed);<br/><br/>}<br/><br/>?><br/>
登录后复制

要是你再加更多东西到这个函数里,它会很快变得难以维护。

好习惯:可管理,集成化的函数

<?<font color="#335533">php</font><br/><br/>function createRssHeader()<br/>{<br/>    return "<rss version=\"2.0\">" .<br/>        "<channel>" .<br/>        "<title>My Great Feed</title>" .<br/>        "<link>http://www.example.com/feed.xml</link>" .<br/>        "<description>The best feed in the world</description>" .<br/>        "<language>en-us</language>" .<br/>        "<pubDate>Tue, 20 Oct 2008 10:00:00 GMT</pubDate>" .<br/>        "<lastBuildDate>Tue, 20 Oct 2008 10:00:00 GMT</lastBuildDate>" .<br/>        "<docs>http://www.example.com/rss</docs>" .<br/>        "<generator>MyFeed Generator</generator>" .<br/>        "<managingEditor>editor@example.com</managingEditor>" .<br/>        "<webMaster>webmaster@example.com</webMaster>" .<br/>        "<ttl>5</ttl>";<br/>}<br/><br/>function createRssFooter()<br/>{<br/>    return "</channel></rss>";<br/>}<br/><br/>function createRssItem($title, $link, $desc, $date, $guid) <br/>{<br/>    $item .= "<item>";<br/>    $item .= "<title>" . $title . "</title>";<br/>    $item .= "<link>" . $link . "</link>";<br/>    $item .= "<description> " . $description . "</description>";<br/>    $item .= "<pubDate>" . $date . "</pubDate>";<br/>    $item .= "<guid>" . $guid . "</guid>";<br/>    $item .= "</item>";<br/>    return $item;<br/>}<br/><br/>function getUserMaxStories($db_link, $default)<br/>{<br/>    $perfsQuery = sprintf("SELECT max_stories FROM user_perfs WHERE user= '%s'",<br/>            mysql_real_escape_string($user));<br/><br/>    $result = mysql_query($perfsQuery, $db_link);<br/><br/>    $max_stories = $default;<br/><br/>    if ($row = mysql_fetch_assoc($result)) {<br/>        $max_stories = $row['max_stories'];<br/>    } <br/><br/>    return $max_stories;<br/>}<br/><br/>function writeRssFeed($user)<br/>{<br/>    // Get the DB connection information<br/>    $settings = parse_ini_file("rss_server.ini");<br/><br/>    // look up the user's preferences...<br/>    $link = mysql_connect($settings['db_host'], $settings['user'], <br/>        $settings['password']) OR die(mysql_error());<br/><br/>    $max_stories = getUserMaxStories($link, 25);<br/><br/>    // go get my data<br/>    $newsQuery = sprintf("SELECT * FROM stories WHERE post_date = '%s'",<br/>            mysql_real_escape_string(time()));<br/><br/>    $result = mysql_query($newsQuery, $link); <br/><br/>    $feed = createRssHeader();<br/><br/>    $i = 0;<br/>    // build the feed...<br/>    while ($row = mysql_fetch_assoc($result)) {<br/>        if ($i < $max_stories) {<br/>            $title = $row['title'];<br/>            $link = $row['link'];<br/>            $description = $row['description'];<br/>            $date = $row['date'];<br/>            $guid = $row['guid'];<br/><br/>            $feed .= createRssItem($title, $link, $description, $date, $guid);<br/><br/>            $i++;<br/>        } else { <br/>            break;<br/>        }<br/>    }<br/><br/>    mysql_close($link);<br/><br/>    $feed .= createRssFooter();<br/><br/>    // write the feed out to the server...<br/>    echo($feed);<br/>}<br/>?><br/>
登录后复制

把长函数分割会导致效率降低,所以要注意,这个好习惯不要使用过度。这样做可能也会引起阅读性差,跟原来人家是一个整体时没什么区别。

注释代码

注释你的代码有时就像你刚着手写代码一样困难。明确注释内容很棘手,因为他要写出代码要做什么。注释变量是一个好主意。在函数头部注释可能不太明显时,就可以告诉阅读者函数要什么参数,有什么返回以及主要的意图。

通常大家会注释代码是做什么的,但这并不必要。如果代码让人困惑以至于你不得不写注释说它是做什么的,这就提示你应该重写它,使它更好懂。命名良好、更加短小、组织合理的代码习惯会让你的代码用不着注释就拥有很高的可读性。

坏习惯:压根没有或者叽叽歪歪的函数注释 (^_^)

例5的注释只给出了代码在做什么——它的通过循环的遍历、加了个数。但是丢了为什么这么做和要做什么。 这会让别人难以不影响原代码的情形下安全修改的做出修改。

例5 :压根没胡或者叽叽歪歪的函数注释

<?<font color="#335533">php</font><br/><br/>class ResultMessage <br/>{<br/>    private $severity;<br/>    private $message;<br/><br/>    public function __construct($sev, $msg) <br/>    {<br/>        $this->severity = $sev;<br/>        $this->message = $msg;<br/>    }<br/><br/>    public function getSeverity()<br/>    {<br/>        return $this->severity;<br/>    }<br/><br/>    public function setSeverity($severity)<br/>    {<br/>        $this->severity = $severity;<br/>    }<br/><br/>    public function getMessage()<br/>    {<br/>        return $this->message;<br/>    }<br/><br/>    public function setMessage($msg)<br/>    {<br/>        $this->message = $msg;<br/>    }<br/>}<br/><br/>function cntMsgs($messages)<br/>{<br/>    $n = 0;<br/>    /* iterate through the messages... */<br/>    foreach($messages as $m) {<br/>        if ($m->getSeverity() == 'Error') {<br/>            $n++; // add one to the result;<br/>        }<br/>    }<br/>    return $n;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/>    new ResultMessage("Warning", "This is a warning!"),<br/>    new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = cntMsgs($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/>
登录后复制

好习惯: 注释函数和类

例6里的注释标明了类和函数的意图。注释表明方法做了什么和为什么做,这会对将来了解代码的意图很有帮助。环境的变化会需要你进行代码修改,这就会让很容易的知道开始时你代码是做什么的。

例6.好习惯:注释函数和类

<?<font color="#335533">php</font><br/>/**<br/> * The ResultMessage class holds a message that can be returned<br/> * as a result of a process. The message has a severity and<br/> * message.<br/> * <br/> * @author nagood<br/> *<br/> */<br/>class ResultMessage <br/>{<br/>    private $severity;<br/>    private $message;<br/><br/>    /**<br/>     * Constructor for the ResultMessage that allows you to assign<br/>     * severity and message.<br/>     * @param $sev See {@link getSeverity()}<br/>     * @param $msg<br/>     * @return unknown_type<br/>     */<br/>    public function __construct($sev, $msg) <br/>    {<br/>        $this->severity = $sev;<br/>        $this->message = $msg;<br/>    }<br/><br/>    /**<br/>     * Returns the severity of the message. Should be one<br/>     * "Information", "Warning", or "Error".<br/>     * @return string Message severity<br/>     */<br/>    public function getSeverity()<br/>    {<br/>        return $this->severity;<br/>    }<br/><br/>    /**<br/>     * Sets the severity of the message<br/>     * @param $severity<br/>     * @return void<br/>     */<br/>    public function setSeverity($severity)<br/>    {<br/>        $this->severity = $severity;<br/>    }<br/><br/>    public function getMessage()<br/>    {<br/>        return $this->message;<br/>    }<br/><br/>    public function setMessage($msg)<br/>    {<br/>        $this->message = $msg;<br/>    }<br/>}<br/><br/><br/>/*<br/> * Counts the messages with the given severity in the array<br/> * of messages.<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return int Count of messages with a severity of "Error"<br/> */<br/>function countErrors($messages)<br/>{<br/>    $matchingCount = 0;<br/>    foreach($messages as $m) {<br/>        if ($m->getSeverity() == "Error") {<br/>            $matchingCount++;<br/>        }<br/>    }<br/>    return $matchingCount;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/>    new ResultMessage("Warning", "This is a warning!"),<br/>    new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = countErrors($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/>
登录后复制

异常处理

写健壮应用时经常会提到的异常处理,一般遵循着80/20原则: 80%的代码用于处理异常或者验证,20%的代码没什么实际的用途。原始的代码通常都是在乐观的环境下编写的。这意味着代码可以在数据正常、一切理解的基础环境中工作的很好。但是这种代码在其生命周期内是脆弱的。在极端的情形中,你得花更多的时间来未很可能永远不会发生的状况编写相应代码。

这个习惯就是要你处理全部的出错情况,而且如果要是不这么做,你的代码永远也完不成。

坏习惯:不处理任何异常

<?<font color="#335533">php</font><br/><br/>// Get the actual name of the <br/>function convertDayOfWeekToName($day)<br/>{<br/>    $dayNames = array(<br/>    "Sunday",<br/>    "Monday",<br/>    "Tuesday",<br/>    "Wednesday",<br/>    "Thursday",<br/>    "Friday",<br/>    "Saturday");<br/>    return $dayNames[$day];<br/>}<br/><br/>echo("The name of the 0 day is:  " . convertDayOfWeekToName(0) . "\n");<br/>echo("The name of the 10 day is:  " . convertDayOfWeekToName(10) . "\n");<br/>echo("The name of the 'orange' day is:  " . convertDayOfWeekToName('orange') . "\n");<br/><br/>?><br/>
登录后复制

好习惯: 防守型编程

例8表明处理并抛出异常是一件很有意义的事情。不只是额外的异常处理可以让代码健壮,但是这有助于提高代码的可读性。这种异常处理为原作者查看何时编写提供了一个很好的说明。

例8.好习惯:防守型编程

<?<font color="#335533">php</font><br/><br/>/**<br/> * This is the exception thrown if the day of the week is invalid.<br/> * @author nagood<br/> *<br/> */<br/>class InvalidDayOfWeekException extends Exception { }<br/><br/>class InvalidDayFormatException extends Exception { }<br/><br/>/**<br/> * Gets the name of the day given the day in the week. Will<br/> * return an error if the value supplied is out of range.<br/> * <br/> * @param $day<br/> * @return unknown_type<br/> */<br/>function convertDayOfWeekToName($day)<br/>{<br/>    if (! is_numeric($day)) {<br/>        throw new InvalidDayFormatException('The value \'' . $day . '\' is an ' .<br/>            'invalid format for a day of week.');<br/>    }<br/><br/>    if (($day > 6)  ($day < 0)) {<br/>        throw new InvalidDayOfWeekException('The day number \'' . $day . '\' is an ' .<br/>            'invalid day of the week. Expecting 0-6.');<br/>    }<br/><br/>    $dayNames = array(<br/>    "Sunday",<br/>    "Monday",<br/>    "Tuesday",<br/>    "Wednesday",<br/>    "Thursday",<br/>    "Friday",<br/>    "Saturday");<br/>    return $dayNames[$day];<br/>}<br/><br/>echo("The name of the 0 day is:  " . convertDayOfWeekToName(0) . "\n");<br/><br/>try {<br/>    echo("The name of the 10 day is:  " . convertDayOfWeekToName(10) . "\n");<br/>} catch (InvalidDayOfWeekException $e) {<br/>    echo ("Encountered error while trying to convert value:  " . $e->getMessage() . "\n");<br/>}<br/><br/>try {<br/>    echo("The name of the 'orange' day is:  " . convertDayOfWeekToName('orange') . "\n");<br/>} catch (InvalidDayFormatException $e) {<br/>    echo ("Encountered error while trying to convert value:  " . $e->getMessage() . "\n");<br/>}<br/><br/>?><br/>
登录后复制

通过检验参数的全法性——这有助于他人使用你需要正确参数的函数——你应该检验它们并抛出异常的大意:

  • 尽量抛出接近错误的异常.
  • 处理每个特殊的异常.


永远,永远不要复制粘贴

把代码复制到你的编辑里的能力是一把双刃剑。一方面,它避免了你参照一些示例后重新再打一遍时出现的错误;另一方面,它让书写相似代码太简单了。

你要避免在你的程序应用中复制粘贴代码。当你发现自己在这样做时,停下来并问自己可不可以把复制的部分重复使用。把相同的代码放在同一个地方可以让你以后修改时更加的轻松,因为要改变都在一起。

坏习惯:相似的代码块

例9表现了除了一些值所在位置之外很相近的几个方法。有些工具可以检验你的代码中复制粘贴的部分(去看看Resources)。

例9.相似的代码块

<?<font color="#335533">php</font><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Error"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countErrors($messages)<br/>{<br/>    $matchingCount = 0;<br/>    foreach($messages as $m) {<br/>        if ($m->getSeverity() == "Error") {<br/>            $matchingCount++;<br/>        }<br/>    }<br/>    return $matchingCount;<br/>}<br/><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Warning"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countWarnings($messages)<br/>{<br/>    $matchingCount = 0;<br/>    foreach($messages as $m) {<br/>        if ($m->getSeverity() == "Warning") {<br/>            $matchingCount++;<br/>        }<br/>    }<br/>    return $matchingCount;<br/>}<br/><br/>/**<br/> * Counts the number of messages found in the array of <br/> * ResultMessage with the getSeverity() value of "Information"<br/> * <br/> * @param $messages An array of ResultMessage<br/> * @return unknown_type<br/> */<br/>function countInformation($messages)<br/>{<br/>    $matchingCount = 0;<br/>    foreach($messages as $m) {<br/>        if ($m->getSeverity() == "Information") {<br/>            $matchingCount++;<br/>        }<br/>    }<br/>    return $matchingCount;<br/>}<br/><br/>$messages = array(new ResultMessage("Error", "This is an error!"),<br/>    new ResultMessage("Warning", "This is a warning!"),<br/>    new ResultMessage("Error", "This is another error!"));<br/><br/>$errs = countErrors($messages);<br/><br/>echo("There are " . $errs . " errors in the result.\n");<br/>?><br/>
登录后复制

好习惯:可复用的带参函数

例10展示了把要复制的代码入到一个方法中的代码修改。另一个修改的方法则把工作代理给了一个新的方法 。编写一个通用的方法要花一些时间来设计,当然这会让你停下来思考,而不是用复制粘贴的组合快捷键。但是这样做会在以后修改时省回第一次多花的时间。

例10.好习惯 :可利用的带参函数

<?<font color="#335533">php</font><br/>    /*<br/>     * Counts the messages with the given severity in the array<br/>     * of messages.<br/>     * <br/>     * @param $messages An array of ResultMessage<br/>     * @return int Count of messages matching $withSeverity<br/>     */<br/>    function countMessages($messages, $withSeverity)<br/>    {<br/>        $matchingCount = 0;<br/>        foreach($messages as $m) {<br/>            if ($m->getSeverity() == $withSeverity) {<br/>                $matchingCount++;<br/>            }<br/>        }<br/>        return $matchingCount;<br/>    }<br/><br/>    /**<br/>     * Counts the number of messages found in the array of <br/>     * ResultMessage with the getSeverity() value of "Error"<br/>     * <br/>     * @param $messages An array of ResultMessage<br/>     * @return unknown_type<br/>     */<br/>    function countErrors($messages)<br/>    {<br/>        return countMessages($messages, "Errors");<br/>    }<br/><br/>    /**<br/>     * Counts the number of messages found in the array of <br/>     * ResultMessage with the getSeverity() value of "Warning"<br/>     * <br/>     * @param $messages An array of ResultMessage<br/>     * @return unknown_type<br/>     */<br/>    function countWarnings($messages)<br/>    {<br/>        return countMessages($messages, "Warning");<br/>    }<br/><br/>    /**<br/>     * Counts the number of messages found in the array of <br/>     * ResultMessage with the getSeverity() value of "Warning"<br/>     * <br/>     * @param $messages An array of ResultMessage<br/>     * @return unknown_type<br/>     */<br/>    function countInformation($messages)<br/>    {<br/>        return countMessages($messages, "Information");<br/>    }<br/><br/>    $messages = array(new ResultMessage("Error", "This is an error!"),<br/>        new ResultMessage("Warning", "This is a warning!"),<br/>        new ResultMessage("Error", "This is another error!"));<br/><br/>    $errs = countErrors($messages);<br/><br/>    echo("There are " . $errs . " errors in the result.\n");<br/><br/>?><br/>
登录后复制

结论

如果当你开发PHP的时候养成了本文中提到的好习惯,你写的代码将会好读、好懂、好维护。编写可维护代码的方式将让你的代码可以高度排错,并告别低级错误。

使用良好命名并用短代码块来组强你的代码会让你的代码简单明了。注明你代码的目的会让它的主旨明确易于理解。异常处理让你的代码健壮。最后,摒弃复制粘贴的恶习让你的代码整洁。

-----------------------------------------------------

玉米寄语:最后的这个复制粘贴的建议让我一身冷汗,想想其实有很多代码都是重复的工作,有时只是为了“快”,而把相似的代码又“复制”了一遍,虽然我没有使用ctrl+c\v 但是也是写了很多类似的代码,看来,review的事儿可以在世界和平的事儿之前考虑了。



本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1663
14
CakePHP 教程
1419
52
Laravel 教程
1313
25
PHP教程
1263
29
C# 教程
1237
24
华为GT3 Pro和GT4的差异是什么? 华为GT3 Pro和GT4的差异是什么? Dec 29, 2023 pm 02:27 PM

许多用户在选择智能手表的时候都会选择的华为的品牌,其中华为GT3pro和GT4都是非常热门的选择,不少用户都很好奇华为GT3pro和GT4有什么区别,下面就就给大家介绍一下二者。华为GT3pro和GT4有什么区别一、外观GT4:46mm和41mm,材质是玻璃表镜+不锈钢机身+高分纤维后壳。GT3pro:46.6mm和42.9mm,材质是蓝宝石玻璃表镜+钛金属机身/陶瓷机身+陶瓷后壳二、健康GT4:采用最新的华为Truseen5.5+算法,结果会更加的精准。GT3pro:多了ECG心电图和血管及安

2 个月不见,人形机器人 Walker S 会叠衣服了 2 个月不见,人形机器人 Walker S 会叠衣服了 Apr 03, 2024 am 08:01 AM

机器之能报道编辑:吴昕国内版的人形机器人+大模型组队,首次完成叠衣服这类复杂柔性材料的操作任务。随着融合了OpenAI多模态大模型的Figure01揭开神秘面纱,国内同行的相关进展一直备受关注。就在昨天,国内"人形机器人第一股"优必选发布了人形机器人WalkerS深入融合百度文心大模型后的首个Demo,展示了一些有趣的新功能。现在,得到百度文心大模型能力加持的WalkerS是这个样子的。和Figure01一样,WalkerS没有走动,而是站在桌子后面完成一系列任务。它可以听从人类的命令,折叠衣物

修复:截图工具在 Windows 11 中不起作用 修复:截图工具在 Windows 11 中不起作用 Aug 24, 2023 am 09:48 AM

为什么截图工具在Windows11上不起作用了解问题的根本原因有助于找到正确的解决方案。以下是截图工具可能无法正常工作的主要原因:对焦助手已打开:这可以防止截图工具打开。应用程序损坏:如果截图工具在启动时崩溃,则可能已损坏。过时的图形驱动程序:不兼容的驱动程序可能会干扰截图工具。来自其他应用程序的干扰:其他正在运行的应用程序可能与截图工具冲突。证书已过期:升级过程中的错误可能会导致此issu简单的解决方案这些适合大多数用户,不需要任何特殊的技术知识。1.更新窗口和Microsoft应用商店应用程

如何修复无法连接到iPhone上的App Store错误 如何修复无法连接到iPhone上的App Store错误 Jul 29, 2023 am 08:22 AM

第1部分:初始故障排除步骤检查苹果的系统状态:在深入研究复杂的解决方案之前,让我们从基础知识开始。问题可能不在于您的设备;苹果的服务器可能会关闭。访问Apple的系统状态页面,查看AppStore是否正常工作。如果有问题,您所能做的就是等待Apple修复它。检查您的互联网连接:确保您拥有稳定的互联网连接,因为“无法连接到AppStore”问题有时可归因于连接不良。尝试在Wi-Fi和移动数据之间切换或重置网络设置(“常规”>“重置”>“重置网络设置”>设置)。更新您的iOS版本:

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

watch4pro好还是gt好 watch4pro好还是gt好 Sep 26, 2023 pm 02:45 PM

watch4pro和gt各自具有不用的特点和适用场景,如果注重功能的全面性、高性能和时尚外观,同时愿意承担较高的价格,那么Watch 4 Pro可能更适合。如果对功能要求不高,更注重电池续航和价格的合理性,那么GT系列可能更适合。最终的选择应根据个人需求、预算和喜好来决定,建议在购买前仔细考虑自己的需求,并参考各种产品的评测和比较,以做出更明智的选择。

如何使用 iPadOS 17.4 优化 iPad 电池寿命 如何使用 iPadOS 17.4 优化 iPad 电池寿命 Mar 21, 2024 pm 10:31 PM

如何使用iPadOS17.4优化iPad电池寿命延长电池续航时间是移动设备体验的关键,iPad是一个很好的例子。如果您觉得iPad电池消耗速度过快,不用担心,在iPadOS17.4中有许多技巧和调整可以显着延长设备的运行时间。本深入指南的目标不仅仅是提供信息,而是改变您使用iPad的方式,增强您的整体电池管理,并确保您可以在无需充电的情况下更长时间地依赖您的设备。通过采用此处概述的做法,您朝着更高效、更谨慎地使用技术迈出了一步,这些技术是根据您的个人需求和使用模式量身定制的。识别主要的能量消耗者

THE是什么币种,THE币值得投资吗? THE是什么币种,THE币值得投资吗? Feb 21, 2024 pm 03:49 PM

THE是什么币种?THE(TokenizedHealthcareEcosystem)是一种数字货币,利用区块链技术,专注于医疗健康行业的创新和改革。THE币的使命是利用区块链技术提高医疗行业的效率和透明度,推动各方之间更高效的合作,包括患者、医护人员、制药公司和医疗机构。THE币的价值和特点首先,THE币作为一种数字货币,具备了区块链的优势——去中心化、安全性高、交易透明等,让参与者能够信任和依赖这个系统。其次,THE币的独特之处在于它专注于医疗健康行业,借助区块链技术改造了传统医疗体系,提升了

See all articles