中秋节反省:粗心大意引发的血案

中秋节前项目报出一个Bug,改了多次都没有解决好,后来发现问题出在一条SQLite删除语句上,这条语句完全没有像我预想的方式运行,而细细一看,确又是自己粗心大意自以为是的理解才会这样写代码的。

看一下这个样例代码:


有发现问题吗?

public int delete(String table, String whereClause, String[] whereArgs)

我把whereClause字符串中的"?"理解成会被whereArgs中的第1个String(whereArgs[0])替换,而实际中并不是直接替换,而是进行和"?"的映射小绑定操作,最终交给这两个值仍然是分别传给SQLite的Native层去操作的(可以查看SQLiteProgram.java类的bindAllArgsAsStrings)。

也就是说,当只有一个值时,如上图第一句代码中"?"被绑定成了"18",操作结果是正确的。但第3条语句,"?"被绑定成"18,22"进,因为不是直接替换,所以在Native层操作时,NOT IN会去匹配你要的内容在不在"18,22"中,而不是去匹配在不在"18"和"22"中,它把"18,22"现解成一个新的字符串,而不是我想的用","分成两个值。

没有不能重现的Bug

再聊一点,这个问题为什么我改了多次才找到问题的根源在这里呢?因为我们调用这个语句的地方与多进程(android:process)有关,而我本机测试时这些进程不会启动,使得NOT IN (?) 中“?”对应的是一个值,所以delete语句的执行结果是对的,而当我把其他进程也启动起来时,这个问题基本上百分百重现。

在面对测试提交的Bug时,常会遇到一些重现概率较低的Bug,这类Bug也非常让开发头疼,因为如果日志正好没有记录下来又不能重现的话,很难解决问题,而且就算你解决了,你怎么证明你把这个问题解决了呢?你无法验证。

下在列举几点对于低重现率Bug可以留意的地方:

  1. 是否有多线程在操作
    很多问题都和这个有关,有些手机重现了,而同样的包在另一些手机上又正常,而当你直接Debug调试时发现完全没有问题。你要知道Debug会让程序运行变慢,而断点处会让当前线程中断(你的断点可能设置在主线程),这种时候你可以往多线程同步等方面想想,这个Bug是多线程问题的概率很大。所以查查是不是有多线程使用共享数据,有时某个线程跑快了就发生问题,而下次这个线程跑慢了就是正常的。

  2. 内存问题
    内存方面的问题是测试无法说明的,他们一般不能判断是内存问题。具体给你的Bug描述里,他们会写这个Bug只发生过一次!那么他们提交的Bug重现步骤基本上也没有意义,因为他们自己按这个步骤来都重现不出来。这样的问题,你可以考虑一下是否和内存有关(内存问题是可以重日志看出一点蛛丝马迹),因为系统在内存紧张时可能会杀掉进程或者销毁Activity并释放它点用的资源,而你的代码没有注意这些边界处理的话,是很有可能发生问题的。
    有时候,我们通过DDMS中把应用的进程直接KILL掉就发现问题百分百重现了。而测试在测试时可能打开了很多应用,使用了很久才产生这个条件,而当问题发生时,系统释放了一部份内存,这个问题产生的前提条件就没了。

  3. 重现步骤是否会涉及一些Android特性
    这种问题也很常见,测试在操作Bug产生的步骤中可能触发了一个系统事件(或者被系统事件中断),但他们可能忘记记录进Bug描述里(测度可能觉得这个事件无关紧要)。如正在测试时,电话或者短信来了,再或者在某个界面手一抖转了一下屏,都可能发生问题。所以当我们无法重现Bug时,不妨在某个步骤里增加一些转屏、销屏或者点击通知栏等操作,也许问题马上就能百分百重现了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容