加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

如何才能成为PHP高手?

发布时间:2022-03-11 22:17:55 所属栏目:PHP教程 来源:互联网
导读:PHP是一门高效的网络编程语言,由于它具有编写灵活、运行快速等优点,迅速成为Web程序员的首选语言。前不久的一份权威调查表明,现在已经有31.6%的网站使用PHP作为主要的服务器端编程语言。 1.懒惰是金 2.编写漂亮的代码 一、懒惰是金 做一个懒惰的程序员
  PHP是一门高效的网络编程语言,由于它具有编写灵活、运行快速等优点,迅速成为Web程序员的首选语言。前不久的一份权威调查表明,现在已经有31.6%的网站使用PHP作为主要的服务器端编程语言。
 
 
  1.懒惰是金
 
  2.编写漂亮的代码
 
  一、懒惰是金
 
  做一个懒惰的程序员吗?这个想法太奇怪了!因为这个世界上最忙碌的人可能就是计算机程序员了。但正是因为程序员太忙了,所以才应该在编程时学会偷懒。
 
  对于一个程序员来说,懒惰的方法有两种:其一,大胆使用现成的别人的程序代码,把这些代码融入到你自己的程序或者项目中去。其二是编写一些有用的代码建立一个函数库,在将来编写程序时可以顺手拈来,省去了许多重复的劳动,自然就可以懒惰一点了。
 
  下面笔者为大家介绍几个通用的函数,这些函数有的来自网上的一些开放源代码的项目,有的精选自邮件列表。如果你能把它们加入到你自己的函数库中,迟早你将会发现自己受益无穷。
 
  1.通用数据库处理函数
 
  和其它的CGI函数相比,PHP的优点之一是具有很强大的数据库处理能力。但是,在PHP中,对于不同的数据库都使用一些特定的函数来专门处理,缺少通用的数据库处理函数。这大大降低了程序代码的可移植性,这也为初学编程的朋友带来了很多不便。
 
  2.变量调试函数
 
  PHP程序的调试一直是一件让人头疼的事,它既不像VB等高级语言那样有集成的编译调试环境,也不想Perl那样可以在Linux或者DOS环境下直接运行。其实,我们完全可以通过灵活地使用echo语句来完成对PHP的调试工作。
  3.追求程序的速度,而不是编程的速度。
 
  下面的几个函数可以让你随时查看程序中任何变量的类型及其值。
 
  以下为引用的内容:
  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 .= "&nbsp;&nbsp;&nbsp;&nbsp;";
     }
     $str .= $var. ==> ;
     $str .= ss_as_string($val, $column+1)." n";
    }
    for ($i = 0; $i < $column; $i++){
     $str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
    }
    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 .= "&nbsp;&nbsp;&nbsp;&nbsp;";
       }
       global $$var;
       $str .= $var. ==> ;
       $str .= ss_as_string($$var, column+1)." n";
      }
      for ($i = 0; $i < $column; $i++){
       $str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
      }
      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($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;
  }
 

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读