最近,修复了项目当中的一些bug,觉着有些思路可以分享出来供大家借鉴。

场景一 开发环境中系统正常运行,测试环境中,部分机器未能正常运行。

解决过程:远程连接了测试环境中的机器,观察了系统的运行情况,确实比较反常。查看日志后,发现出现了“xxx文件未找到”的异常。确认文件存在后,最先想到的就是,xxx依赖文件不存在,导致xxx文件未能正确加载。使用分析工具分析xxx文件依赖项后,发现测试环境确实是缺少了某些文件。从开发环境手动拷贝xxx文件的依赖文件到测试环境后,系统运行正常。

划重点:同一份代码,A环境运行正常,B环境运行异常,最有可能的原因就是环境因素,比如网络原因,磁盘权限原因,运行库缺失等原因。具体的原因分析可以依赖软件系统的日志,如果日志比较详细合理的话,对于分析解决问题有着莫大的帮助。如果,由于一些原因,软件系统没有日志,也可以查看一下操作系统的应用程序日志。当然,操作系统的应用程序日志对一些软件系统崩溃会有记录,但一般的异常情况不会记录。

场景二 逻辑A执行完毕后执行逻辑B,逻辑B执行完后执行逻辑C。逻辑A、B、C均放在try{}catch(){}块中,逻辑C未能正常执行。

解决过程:走读代码发现,逻辑A当中使用了try{}catch(){}块,逻辑B当中也使用了try{}catch(){}块,理论上来说,逻辑C是可以正常运行的。

private void MainFunc()
{
try
{
LogicA();
LogicB();
LogicC();
}
catch(Exception ex)
{
//Do someting
}
} private void LogicA()
{
try
{
//Do someting
}
catch(Exception ex)
{
//Do someting
}
} private void LogicB()
{
try
{
//Do someting
}
catch(Exception ex)
{
//Do someting
throw ex;
}
}

再仔细查看后发现,逻辑B的catch(){}块中使用了throw 语句,当逻辑B中出现异常时,逻辑C自然就不会执行了。预期的结果是,逻辑C需要正常执行,采用的办法是将逻辑C放入finally{}块中,并记录是否有异常发生,如果有异常发生,进行提示或记录。

 private void MainFunc()
{
bool hasError;
try
{
LogicA();
LogicB();
//LogicC();
}
catch(Exception ex)
{
//Do someting
hasError = true;
}
finally
{
if(hasError)
{
//Do something
}
LogicC();
}
}

划重点:在进行异常处理时,除了使用try{}catch(){}块以外,必要的操作应该采用finally{}块操作,确保资源被释放,无论是文件句柄,网络连接还是窗口关闭等。如果发生了异常,应该给出合适的提示,让用户清晰的知道,操作未能成功完成。

以上是修复bug过程中的一点儿小经验、小技巧,望大家笑纳。

献身说法---修复bug时的一些小技巧的更多相关文章

  1. gdb调试运行时的程序小技巧

    使用gdb调试运行时的程序小技巧 标签: 未分类 gdb pstack | 发表时间:2012-10-15 04:32 | 作者:士豪 分享到: 出处:http://rdc.taobao.com/bl ...

  2. linux系统维护时的一些小技巧,包括系统挂载新磁盘的方法!可收藏!

    这里发布一些平时所用到的小技巧,不多,不过会持续更新.... 1.需要将history创建硬链接ln 全盘需要备份硬链接 ln /etc/xxx /home/xxx 2.root用户不可以远程 /et ...

  3. Android 在测试阶段当出现多个测试服务器地址时打包的小技巧

    前提:服务端没有做特殊处理 在开发android网络客户端项目时,不可避免的会用到“测试服务器地址”和“云端服务器地址”等.(有时可能会有多个) 这时在打包给测试那帮哥们时,你就需要一个服务器地址打上 ...

  4. 两个宝藏|关于我在github上冲浪时的一个小技巧。

    你好呀,我是歪歪. 前几天在 github 上冲浪的时候,发现了两个宝藏东西. 我也不藏着掖着了,拿出来给大家分享一下. 这两个宝藏是关于 arthas 和 SOFARegistry 的,这两个东西都 ...

  5. 对于shell脚本参数获取时的一点小技巧

    问题如下: 根据脚本参数的个数$#进行一个循环,在依次输出每个参数$1 $2 $3...... 我有一个循环变量i $i 取到这时的i为1,我想使用这个1再去调用$1,也是就是打印出第一个参数 就是$ ...

  6. 程序员不修复BUG怎么办

    在测试过程中,难免遇到开发人员因为一些原因不想修改个别bug的情况.遇到这种问题时,该如何去推进开发修改bug呢? 一.现状分析 1.开发人员为啥不愿意修复BUG? (1)开发与测试对bug的定义理解 ...

  7. 12个非常实用的JavaScript小技巧

    在这篇文章中将给大家分享12个有关于JavaScript的小技巧.这些小技巧可能在你的实际工作中或许能帮助你解决一些问题. 使用!!操作符转换布尔值 有时候我们需要对一个变量查检其是否存在或者检查值是 ...

  8. javascript的几个小技巧

    1.在循环中缓存array.length 这个技巧很简单,这个在处理一个很大的数组循环时,对性能影响将是非常大的.基本上,大家都会写一个这样的同步迭代的数组. for(var i=0;i<arr ...

  9. Python补充02 Python小技巧

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在这里列举一些我使用Python时积累的小技巧.这些技巧是我在使用Python过程 ...

随机推荐

  1. Gson-记录一个空格引发的json血案

    使用的Gson将json自动装载到Bean,一般情况下,用起来又快又稳. 直到有一天,测试告诉我说,填写地址时,地址里有空格,就会500异常. 我把异常截取出来: Type Exception Rep ...

  2. log4j源码解析

    前言:本文将在slf4j的基础上解释log4j的应用,阅读本文前可先行阅读SLF4J源码解析-LoggerFactory(二) 前言概要 在前言中提到的slf4j的基础,其主要是通过logback的a ...

  3. windows 计划任务执行python脚本

    1.  查找并打开Windows计划任务 2. 创建任务 3. 输入名称 4. 通过触发器设置运行时间或周期 5. 通过操作,设置运行的脚本 a. 操作选择'启动程序' b. 程序或脚本选择 pyth ...

  4. macaca web(4)

    米西米西滴,吃过中午饭来一篇,话说,上回书说道macaca 测试web(3),参数驱动来搞,那么有小伙本又来给雷子来需求, 登录模块能不能给我给重新封装一下吗, 我说干嘛封装,现在不挺好,于是乎,接着 ...

  5. Spark 1.6升级2.x防踩坑指南

    原创文章,谢绝转载 Spark 2.x自2.0.0发布到目前的2.2.0已经有一年多的时间了,2.x宣称有诸多的性能改进,相信不少使用Spark的同学还停留在1.6.x或者更低的版本上,没有升级到2. ...

  6. Redis集群的相关概念

    1.1 redis-cluster架构图 架构细节: (1)所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽. (2)节点的fail是通过集群中超过半数的节 ...

  7. Oracle数据库只读事务和无事务的区别

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt382 Oracle默认情况下(没有事务) 保证了SQL语句级别的读一致性,即 ...

  8. Java线程:线程栈模型

    要理解线程调度的原理,以及线程执行过程,必须理解线程栈模型. 线程栈是指某时刻时内存中线程调度的栈信息,当前调用的方法总是位于栈顶.线程栈的内容是随着程序的运行动态变化的,因此研究线程栈必须选择一个运 ...

  9. 交换机的Ethernet Channel

    端口聚合也叫做以太通道(ethernet channel),主要用于交换机之间连接.由于两个交换机之间有多条冗余链路的时候,STP会将其中的几条链路关闭,只保留一条,这样可以避免二层的环 路产生.但是 ...

  10. 转:【Java集合源码剖析】HashMap源码剖析

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/36034955   您好,我正在参加CSDN博文大赛,如果您喜欢我的文章,希望您能帮我投一票 ...