PHP 用什么代替 echo exit 的调试方法

来源:互联网 发布:淘宝宠物医生 编辑:程序博客网 时间:2024/04/18 22:24
想当年单枪匹马写代码的时候,用 echo+exit 的方法调试程序,效果很不错。但后来工作之后,在公司的服务器上运行着一套程序,在开发用的机上也运行着同一套程序,在开发时还是可以用 echo+exit 的方法调试,调试完后再放上服务器上。但因为是不同的机子,在开发时测试无问题可能上到服务器上就有问题了,于是必须调试服务器上的程序。但服务器上的程序是24小时对外公开的,不能把整个程序直接 exit 了,特别是为多个页面提供服务的公共页面。而且 echo+exit 还是一种猜测的调试方法,一个错误可能要在好几个地方 echo 后才能找到问题的原因,这也延长了解决问题的耗时。怎么办呢?

我的建议是在代码中把需要 echo 的信息都记录下来,而不只是出错时才 echo 部份信息。具体的方法是:建立一个全局变量 $debug ,程序运行时需要 echo 的信息都以字符串的方式追加到这个变量中,每条信息以换行分隔,在页面结束的时候把这串字符串输出。这样无论程序去到哪里运行,都可以通过查看这串字符串达到 echo+exit 方法的效果。

用变量记录是为了避免造成函数依赖,因为可能每一个方法都需要记录信息,在php中,访问一个未定义的变量只会产生一条警告,但调用一个未定义的函数会产生致命错误并中断运行。
虽然每个方法都可能需要记录信息,但运行完一个页面往往只需要调用几个方法,因此每个页面的 $debug 变量记录的数据绝不会太大。
在开发阶段我们也是需要调试的,一般都是用 echo+exit 方法,现在只需要在开发的调试阶段多花一点点时间把调试方法改为记录 $debug 变量的形式,以后就可以一劳永逸了。对于旧代码,无需特意加上 $debug 信息,只需要出问题并调试时加上即可。

综合上面4条,可以看出改为 $debug 的模式成本是很小的,也不会带来其它的麻烦,然而这种模式所带来的收益却比 echo+exit 大得多。
原创粉丝点击