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