快速业务通道

怎样才能成为PHP高手?学会"懒惰"的编程

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-25
lumn; $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 .= "&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($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.速度测试函数

  为了优化代码,我们需要一种可以测试代码运行时间的方法,从而来选择最优的代码。下面的函数可以测试运行代码所需的

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号