您的位置:首页 > 编程语言 > PHP开发

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

2013-01-26 14:35 573 查看
想当年单枪匹马写代码的时候,用 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 大得多。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: