bug修理厂(二)拥有产品经理和架构师视野的程序员

所属文章系列及序号:寻找尘封的银弹:bug修理厂(二)



当我们经过本系列上一篇文章的洗礼之后,又有一座山峰需要攀登:这是不是一个bug。

这又是一个看似简单的问题。

有时最简单的问题,最容易被人忽略。有一次,我遇到一个很奇怪的bug,因为无法重现,所以我就只能通过看日志文件来寻找线索。看着看着,我发现那个日志的内容,并不是最新代码写进去的,那一瞬间,我明白了:用户很可能是使用了错误的安装包!于是我就按照这个思路去排查发给用户的安装包,果然是发错了。我再用旧的安装包测试,不出所料地重现了那个bug,这从侧面映证了发错安装包的错误。

所以就得出了第一条原则:排查用户的安装包。


【不是bug的情况】

这里列举一下“不是bug”的情况:

一、排查用户的安装包,如上文所述。

二、排查是不是用户的环境配置出现了问题,说起来,这算是“技术支持”该做的事情,不过有时还是有些bug是“技术支持”忽略的,有时甚至是需要代码背景才能洞察到是环境配置出了问题。

三、用户用错的情况:例如用户必须先点击“编辑”按钮才能开始编辑界面上的数据。

四、说明书里没有提到,但属于常识的情况:例如用手指点击手机屏幕时不能沾水,又如手机操作系统有时会自动重启。

五、上面这些还算容易理解,不过下面这条隐秘常识,会把很多人绕进去:例如某公共场所公告里写着“禁止随地吐痰”。可能有人会在这里扔矿泉水瓶,他会直觉地认为“这里只是不允许吐痰,但没说不允许扔垃圾”。

而“禁止随地吐痰”意味着保持环境清洁,“禁止扔垃圾”应该在这个范围内,再进一步说,“随地大小便”更是要禁止的。类似的情况很多,它们都属于一类,就算能穷举完全,让人看了流水账式的长长列表之后,只想抓狂,谁还有心情去记住这些内容,所以最好的方式是只写一条。这也解释了,2000多年前,刘邦带兵攻占秦朝首都咸阳之后,只与民“约法三章”而民心悦服的原因。而这就是隐秘常识。

这里我们展开一下:科学思维也好,哲学思维也好,大体上是想把问题的所有方面都展现在表面上,让大家都可以讨论,我们从小就是学着这套理论长大的。而真实的世界是复杂的,不可能穷举所有的情况,所以我们要时刻关注自己的思维方式,不能死扣那个“表面上”的道理。其实,世界上一直都存在这样一种思想:

最关键的成功决策,往往都是科学和哲学无法解释的!

就像前文提到的“隐秘常识”,它符合哪条科学原理?就算符合,之后它就变成了一条“定律”,时间长了,“定律”多到没有人能记得全。当“定律”的数量堪比地球上沙子数量时,满载着这种数量级“定律”的科学之船,还如何在时空中继续航行?

对于判断“是不是bug”来说,情况是无穷无尽的,我们能做的就是让自己保持一颗突破惯性思维的心、一颗突破舒适区的心!


【是bug的情况】

“是bug”的情况中,又分为两类:不可修复、可修复。

一、不可修复:一般都是由于系统限制而不可修复。

有时,这些限制会变成可修复的,因为系统架构有所变化,原来无法修复而现在可以修复了,也可能因为换了一个开发者而找到了解决方案。

我曾经发现过一个很奇特的情况:在Oracle数据库客户端中输入一条SQL,如果结尾是随意输入的字符串,例如“select * from t1 abc;”,令人大吃一惊的是,Oracle居然不报错,而返回结果!

我觉得对于这种情况,Oracle是不会写入系统限制文档的。关于这个现象,我没有看到任何文档里提到过它。不过据我的研究,很多数据库都使用lex和yacc作为词法和语法解析器,而yacc有一个预取一个token的机制,预取之后的那个token,最后找不到匹配值,就直接忽略而不报错。

这种情况也许可以算作“不必修复”。

二、可修复:再次分为“是bug”,或“是需求”。

区分出Bug或需求并不难:说明书已经告诉用户,在某种情况下,做某种操作,一定会有某种结果,而实际结果和期望结果不相符,这是bug。而需求是:说明书没有告诉用户,而用户想要的一个功能。

难点在于,必须判断出:需求是不是符合模型、需求是不是符合产品方向。

需求是不是符合模型:我们开一个脑洞,假设人力资源不受限制,全世界的开发者一起做这个需求,这个需求能不能做出来?这要是再做不出来,一般都是在逻辑上自相矛盾的情况。这种情况我遇到过,但是很难通过一篇文章描述出来,此处我只举一个简单的例子,例如用户想让系统支持1+1=3。作为开发者,只需知道有“需求不符合模型”这种情况即可,遇到具体问题的时候再具体分析。

需求是不是符合产品方向:具体来说,就是与现有系统是否兼容,与产品发展方向是否兼容。例如:用户想在某一个界面中采取独特的显示风格,通过查看代码发现:这个界面会被多处复用,新做一个是可以,但会导致产品多个功能相关界面风格不一致,所以作为产品策略可以委婉拒绝。

至于现有团队能不能实现它,是属于较低层次的问题,我会在后续文章中讨论。


作于2018-3-25

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,019评论 25 707
  • 所属文章系列及序号:寻找尘封的银弹:bug修理厂(一) 看似没有什么营养的bug描述里,其实蕴含着两个关键要素,往...
    子栀说历史阅读 595评论 0 9
  • 寒夜寂寥 徒留一地 温婉的雪 我在风中 踏过 零下几度的眷恋 月光 静静洒下 云层交织的伤悲 我在南方 与北方的你...
    追摩阅读 405评论 0 3
  • 现在一思考问题,就出汗
    mimikatz阅读 154评论 0 0