用户名: 密码: 免费注册 忘记密码? 网站地图 | 加入收藏 | 设为首页
首页 | 新闻 | 工具 | 系统 | 办公 | 聊天 | 多媒体 | 网页 | 运营 | 平面 | 欣赏 | 数据库 | 程序 | 服务器 | 组网
网页 | 3dmax | Ghost | Windows Xp| Dreamweaver | photoshop | Flash | office | Alexa | Css | QQ | Asp | PHP | Jsp | Access
Flash MX 2004入门 | 网站推广策略 | CorelDRAW入门 | ASP学习 | 网站建设大师功 | Word入门
  iTbulo.com > 学院 > 程序开发教程 > PHP教程 > PHP基础教程 > 文章正文
怎样才能成为PHP高手?学会"懒惰"的编程
iTbulo.COM 2006-11-16 天极()

  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;
}

  现在可以轻松地检查任何一段代码的执行时间了,甚至我们可以同时使用多个计时器,只需在使用上述的几个函数时设定不同的参数作为计时器的名称就可以了。

上一页  [1] [2] [3] [4] [5] 下一页

文章搜索
相关资讯
相关文章 相关下载
php4和php5区别
用PHP自动把纯文本转换成Web页面
用实例分析PHP5异常处理
缺陷月项目启动 披露PHP脚本语言漏洞
Windows 下 PHP 环境的配置
焦点信息