提供有用的错误信息
——
高效程序员的
45
个习惯之习惯37
“不要吓着用户,吓程序员也不行。要提供给他们干净整洁的错误信息。要使用类似‘用户错误。替换,然后继
续。’这样让人舒服的词句。”
当应用发布并且在真实世界中得到使用之
后,仍然会发生这样那样的问题。比如计算模块可能出错,与数据库服务器之间的连接也可能丢失。当无法满足用户需求时,要以优雅的方式进行处理。
类似的错误发生时,是不是只要弹出一条
优雅且带有歉意的信息给用户就足够了?并不尽然。当然了,显示通用的信息,告诉用户发生了问题,要好过由于系统崩溃造成应用执行错误的动作,或者直接关闭
(用户会因此感到困惑,并希望知道问题所在)。然而,类似“出错了”这样的消息,无法帮助团队针对问题做出诊断。用户在给支持团队打电话报告问题时,我们
希望他们提供足够多且好的信息,以帮助尽快识别问题所在。遗憾的是,用很通用的错误消息,是无法提供足够的数据的。
针对这个问题,常用的解决方案是记录日
志:当发生问题时,让应用详细记录错误的相关数据。错误日志最起码应该以文本文件的形式维护。不过也许可以发布到一个系统级别的事件日志中。可以使用工具
来浏览日志,产生所有日志信息的
RSS feed
,以及诸如此类的辅助方式。
记录日志很有用,可是单单这样做是不够
的:开发人员认真分析日志,可以得到需要的数据;但对于不幸的用户来说,起不到任何帮助作用。如果展示给他们类似下图
中的信息,他们还是一点头绪都没有
——
不知道自己到底做错了什么,应该怎么做可以绕过这个错误,或者在给技术支持打电话时,应该报告什么。
如果你注意的话,在开发阶段就能发现这
个问题的早期警告。作为开发人员,经常要将自己假定为用户来测试新功能。要是错误信息很难理解,或者无助于定位错误的话,就可以想想真正的用户和支持团
队,遇到这个问题时会有多么困难了(见图
7-2
)。
图
7-2
无用的异常信息
例如,假定登录
UI
调用了应用的中间层,后台向数据访问层发送了一个请求。由于无法连接数据库,数据访问层抛出一个异常。这个异常被中间层用自己的异常包裹起
来,并继续向上传递。那么
UI
层应该怎么做呢?它至少应该让用户知道发生了系统错误,而不是由用户的输入引起的。
接下来,用户会打电话并且告诉我们他无
法登录。我们怎么知道问题的实质是什么呢?日志文件可能有上百个条目,要找到相关的细节非常困难。
实际上,不妨在显示给用户的信息中提供
更多细节。好比说,可以看到是哪条
SQL
查询或存储过程发生了错误;这样可以很快找到问题并且修正,而不是浪费大把的时间去盲目地碰运气。不过另一方面,在生产系统中,向用户显示数
据连接问题的特定信息,不会对他们有多大帮助。而且有可能吓他们一跳。
一方面要提供给用户清晰、易于理解的问
题描述和解释,使他们有可能寻求变通之法。另一方面,还要提供具备关于错误的详细技术细节给用户,这样方便开发人员寻找代码中真正的问题所在。
下面是一种同时实现上述两个目的方式:
图
中显示了清晰的错误说明信息。该错误信息不只是简单的文本,还包括了一个超链接。用户、开发人员、测试人员都可以由此链接得到更多信息,如图
7-
3
、图
7-4
所示。
图
7-3
带有更多细节链接的异常信息
图
7-4
供调试用的完整详细信息
进入链接的页面,可以看到异常(以及所
有嵌套异常)的详细信息。在开发时,我们可能希望只要看到这些细节就好了。不过,当应用进入生产系统后,就不能把这些底层细节直接暴露给用户了,而要提供
链接,或是某些访问错误日志的入口。支持团队可以请用户点击错误信息,并读出错误日志入口的相关信息,这样支持团队可以很快找到错误日志中的特定细节。对
于独立系统来说,点击链接,有可能会将错误信息通过电子邮件发送到支持部门。
除了包括出现问题的详细数据外,日志中
记录的信息可能还有当时系统状态的一个快照(例如
Web
应用的会话状态)。
使用上述信息,系统支持团队可以重建发
生问题的系统状态,这样对查找和修复问题非常有效。
错误报告对于开发人员的生产率,以及最
终的支持活动消耗成本,都有很大的影响。在开发过程中,如果定位和修复问题让人倍受挫折,就考虑使用更加积极主动的错误报告方式吧。调试信息非常宝贵,而
且不易获得。不要轻易将其丢弃。
展示有用的错误信息
提供更易于查找错误细节的方式。发生问题时,要展示出尽量多的支持细节,不过别让用户陷入其中。
区分错误类型
程序缺陷。
这些是真正的 bug ,比如 NullPointerException 、缺少主键等。用户或者系统管理员对此束手无策。
环境问题。 该类别包括数据库连接失败,或是无法连接远程 Web Services
、磁盘空间满、权限不足,以及类似的问题。程序员对此没有应对之策,但是用户也许可以找到变通的方法,如果提供足够详细的信息,系统管理员应该可以解决这
些问题。
用户错误。 程序员与系统管理员不必担心这些问题。在告知是哪里操作的问题后,用户可以重新来过。
通过追踪记录报告的错误类型,可以为受众提供更加合适的建议。
切身感受
错误信息有助于问题的解决。当问题发生
时,可以详细研究问题的细节描述和发生上下文。
平衡的艺术
-
像“无法找到文件”这样的错误信息,就其本身而言无助于问题的解决。“无法打开
/andy/project/main.yaml
以供读取”这样的信息更有效。
-
没有必要等待抛出异常来发现问题。在代码关键点使用断言以保证一切正常。当断言失败时,要提供与异常报告同样详细的信息。
-
在提供更多信息的同时,不要泄露安全信息、个人隐私、商业机密,或其他敏感信息(对于基于
Web
的应用,这一点尤其重要)。
-
提供给用户的信息可以包含一个主键,以便于在日志文件或是审核记录中定位相关内容。
分享到:
相关推荐
【优秀程序员的十个习惯】 1. 持续学习与跟进新技术:作为优秀程序员,保持对新知识的渴望至关重要。不断学习新的编程语言、框架和工具,关注行业动态,参与专业社区讨论,如CSDN、ITPUB、CHINAUNIX、digg.com等,...
【优秀程序员45个习惯】是一本旨在提升程序员专业素养的书籍,由敏捷开发领域的权威Venkat Subramaniam和Andy Hunt共同撰写。这45个习惯覆盖了态度、学习、开发流程、用户、编程以及团队协作等多个方面,旨在帮助...
本书名为《高效程序员的45个习惯 敏捷开发修炼之道》,由Venkat Subramaniam和Andy Hunt两位作者共同撰写。书中所提到的45个习惯,不仅涉及软件开发过程、编程和调试工作,还包括了开发者的个人态度、项目和团队管理...
[12]优秀程序员之路——C++开发经验及技巧大汇总.zip上位机开发VC串口学习资料源码下载[12]优秀程序员之路——C++开发经验及技巧大汇总.zip上位机开发VC串口学习资料源码下载[12]优秀程序员之路——C++开发经验及...
《高级程序员的45个好习惯》一文,详细列举并解读了这些高效实践,涵盖从敏捷开发到学习态度,再到软件交付、敏捷反馈、编码规范和调试策略等多个方面,旨在为程序员提供一个提升自身能力的指南。 首先,敏捷开发...
以下是对标题和描述中提到的十个程序员习惯的详细解释: 1. **学无止境**:持续学习是优秀程序员的基石。随着技术的快速发展,必须不断关注新出现的语言、框架和编程实践,通过阅读专业文章、参加在线讨论和社区...
优秀程序员的45个习惯.rar ok good
优秀程序员的45个好习惯,看看总有好处的
程序员——必看的文档 程序员——必看的文档 程序员——必看的文档 程序员——必看的文档
标题中的“程序员的结构化思维方法——一个思维脑图模板”揭示了本主题的核心,即如何运用结构化思维来提升编程能力。结构化思维是指通过系统性、逻辑性的思考方式来解决问题,它对于程序员来说至关重要,因为编程...
程序员晋升.doc————电子版_doc版
在这个“优秀程序员之路——ASP.NET开发经验及技巧大汇总”中,我们将深入探讨ASP.NET的核心概念、开发实践以及各种实用技巧,帮助你提升编程技能,成为一名出色的开发者。 首先,ASP.NET的基础知识是必不可少的。...
黑马程序员——Android移动开发源码
在“程序员如何从小白到大神——免费程序课程培训宣传ppt模板.rar”这份压缩包中,您会发现一个精致的PPT模板,这个模板不仅为初学者描绘了一条清晰的成长路线图,同时,它也能够帮助程序课程培训机构更好地展示其...
标题《优秀程序员之路——C开发经验及技巧大汇总》指的是向程序员介绍和总结在C语言开发过程中积累的经验和技巧。C语言作为编程界经典的语言之一,对于初学者和资深程序员都有着重要的学习价值。描述部分罗列了文章...
程序员之路——一个老程序员对刚上大学的学弟学妹的忠告.
我的成长记1:手把手教你如何画出令人称赞的图(程序员必读)(csdn)————程序