课程咨询 :027-87185216 QQ:2490085651

武汉PHP培训 > 达内新闻 > 优秀的PHP开发者是怎样炼成的?
  • 优秀的PHP开发者是怎样炼成的?

    发布:第一PHP社区      来源:第一PHP社区      时间:2016-06-15

  •     PHP是一门高效的网络编程语言,由于它具有编写灵活、运行快速等优点,迅速成为Web程序员的首选语言。那么怎样才能成为一个优秀的PHP开发者呢?武汉php培训达内专家为你讲解:

        要成为一名PHP编程高手并不容易,并不像很多人想象的那样,只要能够飞快地编写几条简单的代码去解决一个复杂的问题就是PHP编程高手了,真正的PHP高手还需要考虑更多的其它问题。以下三条准则是一名成熟的PHP程序员在编程中应该首先遵循的准则。
        做一个懒惰的程序员吗?这个想法太奇怪了!因为这个世界上最忙碌的人可能就是计算机程序员了。但正是因为程序员太忙了,所以才应该在编程时学会偷懒。对于一个程序员来说,懒惰的方法有两种:
        其一,大胆使用现成的别人的程序代码,把这些代码融入到你自己的程序或者项目中去。其二是编写一些有用的代码建立一个函数库,在将来编写程序时可以顺手拈来,省去了许多重复的劳动,自然就可以懒惰一点了。这两种偷懒的方法都非常适合PHP程序员了。
        首先,PHP是在自由开放的环境中诞生和成长的一门语言。在世界各地,有成千上万的程序员,他们一直在为PHP的完美而不断奋斗,他们也愿意和别人分享自己的聪明才智和自己编写的代码。你每天都可以从一些PHP网站、邮件列表、新闻组发现大量的优秀的程序代码。
        这样说,我并不是鼓励你整天等着让别人为你编写代码,但是你可以“站在伟人的肩膀上”,充分发扬“拿来主义”,聪明地应用别人的程序代码可以节省你大量时间。其次,在PHP中,你可以方便地建立自己的函数库,这样可以在你以后编写程序时省去很多麻烦。
        下面笔者为大家介绍几个通用的函数,这些函数有的来自网上的一些开放源代码的项目,有的精选自邮件列表。如果你能把它们加入到你自己的函数库中,迟早你将会发现自己受益无穷。
        1.通用数据库处理函数
        和其它的CGI函数相比,PHP的优点之一是具有很强大的数据库处理能力。但是,在PHP中,对于不同的数据库都使用一些特定的函数来专门处理,缺少通用的数据库处理函数。这大大降低了程序代码的可移植性,这也为初学编程的朋友带来了很多不便。
        在网上,许多程序员都通过封装类解决了这个问题。他们编写了统一的函数用来处理任何流行的数据库——不管是在Linux世界深受欢迎的Mysql还是在Windows平台上广泛流行的SqlServer。
        就笔者个人来说,非常喜欢使用这些函数,因为可以直接使用一些简单的诸如”query”、”next_record”之类的函数,而不需要考虑数据库的连接、数据库句柄这些复杂的东西,更不需要考虑使用的是何种数据库。
        2.变量调试函数
        PHP程序的调试一直是一件让人头疼的事,它既不像VB等高级语言那样有集成的编译调试环境,也不想Perl那样可以在Linux或者DOS环境下直接运行。其实,我们完全可以通过灵活地使用echo语句来完成对PHP的调试工作。下面的几个函数可以让你随时查看程序中任何变量的类型及其值。
     
        function ss_array_as_string (&$array, $column = 0) {
        $str = “Array(n”;
        while(list($var, $val) = each($array)){
        for ($i = 0; $i < $column+1; $i++){
        $str .= “    ”;
        }
        $str .= $var. ==> ;
        $str .= ss_as_string($val, $column+1).” n”;
        }
        for ($i = 0; $i < $column; $i++){
        $str .= “    ”;
        }
        return $str.);
        }
        function ss_object_as_string (&$object, $column = 0) {
        if (empty($object->classname)) {
        return “$object”;
        }
        else {
        $str = $object->classname.”( n”;
        while (list(,$var) = each($object->persistent_slots)) {
        for ($i = 0; $i < $column; $i++){
        $str .= “    ”;
        }
        global $$var;
        $str .= $var. ==> ;
        $str .= ss_as_string($$var, column+1).” n”;
        }
        for ($i = 0; $i < $column; $i++){
        $str .= “    ”;
        }
        return $str.);
        }
        }
        function ss_as_string (&$thing, $column = 0) {
        if (is_object($thing)) {
        return ss_object_as_string($thing, $column);
        }
        elseif (is_array($thing)) {
        return ss_array_as_string($thing, $column);
        }
        elseif (is_double($thing)) {
        return “Double(“.$thing.”)”;
        }
        elseif (is_long($thing)) {
        return “Long(“.$thing.”)”;
        }
        elseif (is_string($thing)) {
        return “String(“.$thing.”)”;
        }
        else {
        return “Unknown(“.$thing.”)”;
        }
        }
     
        需要的时候,在程序中简单地加入下面的一条代码即可查看程序中的所使用的变量(包括数组和对象)的类型和值:
        echo ss_as_string($my_variable);
        使用下面的语句,我们可以直接查看程序中所有的变量的值:
        echo ss_as_string($GLOBALS);
        3. 控制Log信息的函数
        调试PHP程序的另外一种重要的方法就是查看Log信息。如果能够方便地控制Log信息的级别以及Log信息的显示内容,将会给程序调试带来更多的便利。下面的几个函数可以方便地实现这个功能。
     
        $ss_log_level = 0;
        $ss_log_filename = /tmp/ss-log;
        $ss_log_levels = array(
        NONE => 0,
        ERROR => 1,
        INFO => 2,
        DEBUG => 3);
        function ss_log_set_level ($level = ERROR) {
        global $ss_log_level;
        $ss_log_level = $level;
        }
        function ss_log ($level, $message) {
        global $ss_log_level, $ss-log-filename;
        if ($ss_log_levels[$ss_log_level] < $ss_log_levels[$level]) {
        // 不显示Log信息
        return false;
        }
        $fd = fopen($ss_log_filename, “a+”);
        fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message.”n”);
        fclose($fd);
        return true;
        }
        function ss_log_reset () {
        global $ss_log_filename;
        @unlink($ss_log_filename);
        }
     
        在上面的函数中,有四个Log级别变量。运行PHP程序时,只有当Log的级别低于预设的级别值时,Log信息才可以被记录和显示出来。例如,在程序中加入如下的一条语句:
        ss_log_set_level(INFO);
        那么,运行PHP程序时,只有ERROR和INFO级别的LOG信息才能被记录和显示出来,DEBUG级的信息则被忽略了。除此之外,我们还可以设定显示的信息内容,其语句如下:
     
        ss_log(ERROR, “testing level ERROR”);
        ss_log(INFO, “testing level INFO”);
        ss_log(DEBUG, “testing level DEBUG”);
     
        你也可以随时使用下面的语句清空LOG信息:
        ss_log_reset();
        4.速度测试函数
        为了优化代码,我们需要一种可以测试代码运行时间的方法,从而来选择最优的代码。下面的函数可以测试运行代码所需的时间:
     
        function ss_timing_start ($name = default) {
        global $ss_timing_start_times;
        $ss_timing_start_times[$name] = explode( , microtime());
        }
        function ss_timing_stop ($name = default) {
        global $ss_timing_stop_times;
        $ss_timing_stop_times[$name] = explode(, microtime());
        }
        function ss_timing_current ($name = default) {
        global $ss_timing_start_times, $ss_timing_stop_times;
        if (!isset($ss_timing_start_times[$name])) {
        return 0;
        }
        if (!isset($ss_timing_stop_times[$name])) {
        $stop_time = explode(, microtime());
        }
        else {
        $stop_time = $ss_timing_stop_times[$name];
        }
        $current = $stop_time[1] - $ss_timing_start_times[$name][1];
        $current += $stop_time[0] - $ss_timing_start_times[$name][0];
        return $current;
        }
     
        现在可以轻松地检查任何一段代码的执行时间了,甚至我们可以同时使用多个计时器,只需在使用上述的几个函数时设定不同的参数作为计时器的名称就可以了。
        5.调试和优化数据库的操作
        对于数据库来说,运行速度是至关重要的。尽管很多书籍和文章都讲授了一些快速运行数据库的方法,但是所有的方法都必须经过实践的检验。下面我们将把PHPLib函数库中的query()函数和上面介绍的几个函数综合起来编写成新的query()函数,和原先的函数相比,这个函数增加了运行时间的监测功能。
     
        function query($Query_String, $halt_on_error = 1) {
        $this->connect();
        ss_timing_start();
        $this->Query_ID = @mysql_query($Query_String,$this->Link_ID);
        ss_timing_stop();
        ss_log(INFO, ss_timing_current(). Secs - .$Query_String);
        $this->Row = 0;
        $this->Errno = mysql_errno();
        $this->Error = mysql_error();
        if ($halt_on_error && !$this->Query_ID) {
        $this->halt(“Invalid SQL: “.$Query_String);
        }
        return $this->Query_ID;
        }
     
        编写漂亮的代码
        1.将后台程序与前端程序分开
        在编写PHP程序时,有些代码是用来处理一些事务,例如操作数据库、进行数学运算等,而另外的一些代码则只是事务处理的结果显示出来,例如一些使用echo语句将结果以HTML的格式显示在Web浏览器上的PHP代码以及那些直接嵌入PHP程序的HTML代码。首先我们应该清晰地区分这两种代码,把前者称为后台程序,把后者称为前端程序。
        因为PHP是一种嵌入式编程语言,也就是说,所有的PHP代码都可以嵌入到HTML代码之中,这为程序的编写带来了许多便利之处。但是,“物极必反”,如果在一段较长的程序中将PHP代码和HTML代码混合编写,这将使程序杂乱无章,不利于程序的维护和阅读。
        所以我们需要尽可能地将这些程序中混杂于HTML代码中的PHP代码移植出来,在专门的文件中将这些代码封装成函数,然后在HTML代码中使用include语句来包含这些文件,在适当的位置调用这些函数即可。
        这种做法一方面使HTML代码和PHP代码都简单易读,另一方面因为HTML代码需要不断更新,而这种分离的方法可以确保后台程序不会被破坏。同前端程序不同,后台程序更多追求的是稳定、结构化,极少更改,所以应该认真地设计和管理。其实,在设计台程序时,投入大量时间是值得的,“现在栽树,以后乘凉”,在以后的设计工作中将可以轻松地使用现在编写的后台程序。
        2.灵活使用包含文件
        正如前面所说的那样后台程序应当安排在一系列的包含文件中。包含文件可以通过include语句在需要时动态装入,也可以在php.ini文件中通过使用auto_prepend_file指令预先自动装入。如果使用后一种方法的话,虽然取得了一劳永逸的好处,但是也有一些缺点值得我们注意。下面的一段代码向我们展示了解析一个庞大的包含文件需要一定的时间:
     
        require(timing.inc);
        ss_timing_start();
        include(test.inc);
        ss_timing_stop();
        echo
        .ss_timing_current().
        ;
        ?>
     
        在上面的代码中,test.inc是一个1000行的包含文件,运行的结果显示,解析这个包含文件花费了0.6秒钟,对于一个大型网站来说,这个速度并不是可以忽略不记的。使用包含文件的另外一个缺点是:如果一个文件中的一个语句发生错误,将会使整个网站的PHP程序都无法运行。所以使用起来也及其小心。其实,对包含文件稍做处理,即可以使包含文件只在需要时进行解析。下面的代码使abc.inc文件只在程序需要时才作解析:
        if ( defined( __LIBA_INC) ) return; define( __LIBA_INC, 1 ); /* * 代码... */ ?>
     
        3.使用面向对象的编程方法
        PHP也是一种面向对象的语言,面向对象的编程方法是优秀的程序员们非常推崇的一种软件设计方法,在PHP编程中可以充分发挥面向对象语言的优势,对编程中的对象进行封装。在前面的代码中,我们使用了面向对象的方法,例如在管理数据库时,我们将query()函数封装进数据库类中,这极大地方便了代码的管理,增加了程序的可读性。
    推荐文章

上一篇:PHP浮点数显示和转成字符串

下一篇:追求程序速度,而不是编程的速度

最新开班日期  |  更多

PHP高级开发工程师定制班

PHP高级开发工程师定制班

开班日期:3/15

PHP高级开发工程师周末班

PHP高级开发工程师周末班

开班日期:3/15

PHP高级开发工程师精品班

PHP高级开发工程师精品班

开班日期:3/15

PHP高级开发工程师就业班

PHP高级开发工程师就业班

开班日期:3/15

  • 地址:武汉市洪山区洪山亚贸广场B座12楼
  • 课程培训电话:027-87185216 QQ:2490085651     全国服务监督电话:400-827-0010
  • 服务邮箱 ts@tedu.cn
  • 2001-2016 达内时代科技集团有限公司 版权所有 京ICP证8000853号-56