论概念模型的重要性--对一次 bug 的思考

背景

我们在做一个 application engine ,涉及到今天要讲的内容有两部分,运行时环境和对象解析库。运行时环境顾名思义就是用户代码运行时的环节,类似于 jvm ,而对象解析库就类似于 javac + classloader 。这两部分基本上同时进行开发的,也就是说在运行时环境还没确定已何种方式使用对象解析库时,对象解析库就开始了设计和开发的工作。而我就是那个设计和开发的人。

需求

因为当时运行时环境还在设计和开发中,而我拿到的需求是写一个较为通用的解析库,负责解析对象文件并装配上一些预定义的方法。

设计

因为对象具体的行为是由运行时环境来执行的,而解析库又要负责解析对象应该具备哪些行为,并把相应的行为定义上去。所以我就定义了一个接口来表示所有的原子行为,然后解析对象并装配上行为(有可能是原子行为或原子行为的组合)。当运行时环境需要使用解析库时,实现原子行为的接口即可。

选择

解析库是在运行时之前开发完成的,之后我又去做了别的事情。等到运行时需要使用解析库时,才发现两个设计人员的概念模型是不一致的。在我的想法里,解析库是可以运行在不同运行时环境的,所以我定义了一组原子行为由运行时环境来实现。而设计运行时环境的人想法是由环境对外提供一个标准方法,解析库通过这个方法实现所有对象的行为。

可以说解析库就是为运行时环境而生的,所以解析库要改。那么有两个选择摆在我面前。

  • 重构解析库

  • 写一个适配器,适配器使用环境提供的标准方法实现解析库借口定义的原子行为

其实我的优先选择是重构,但考虑到时间因素,最后采取了第二个方案。

重点来了

适配器很快就写完了,整个系统也通过跑了几个简单的 demo 得到了验证。于是我又去忙别的事情了。之后的莫一天,有一个验证别的模块的功能跑不通,于是怀疑是解析库的 bug 。业务逻辑是这样的:

环境先提供了一个标准方法来解析一批对象,这时候对象的表现是正常的。

环境又提供了另一个标准方法来解析另一批对象,这时候这批对象的表现也是正常的。

接着环境再调用第一批对象时就表现出了异常。

其实碰到这样的问题,最简单的方式就是在解析库里加一个这种场景的测试,就知道是不是解析库的问题了。然而当时我的第一选择是通过逻辑推断来定位 bug ,因为当解析完成时,对象和方法的关系就已经绑定了,如果起先没有问题,而后来出现问题,那很有可能是这个方法被变更了。所以基本上花了十几分钟来检查环境的代码和 demo 的代码可能存在什么问题。然后又大概花了五分钟来说明我推断的理由,所以差不多浪费了二十分钟后,我终于选择增加一个场景测试来判断问题。而加入这个测试只花了不到五分钟,然后两分钟后就定位到问题了,最后修改的代码在十行内,当然修改方案想的时间比较久。

事后下班回家的路上我在想当时的选择是否正确?在我听完 bug 描述之后,几乎本能的要写一个测试来证明这不是解析库的问题,然而后来我的选择却不是这个,我试着分析自己的心理。首先无论引起 bug 真实的原因是什么,这个测试都是要加的。但如果加了测试以后证明不是解析库的 bug ,问题还是没有解决,需要继续寻找问题的所在。而当时听完描述之后我自信的认定这不可能是解析库的问题,所以想要跳过写测试的那一阶段,直接进入找问题的阶段。

这里看上去是我过分自信的问题,其实自信不是问题,而是我的判断依据出了问题。在我的概念模型里对象和方法的关系在解析时就做了绑定,而解析库在解析时实际的行为是绑定对象和原子行为实现类的关系。运行时虽然定义了两个不同的方法,但原子行为实现类却是一个(原先的概念模型里一个环节一个实现类是合理的)。问题就在于我脑子里的概念模型与系统实际的概念模型不一致,所以才导致我认为不会出问题的地方出了问题。这其实也是当初我优先选择重构解析库的原因。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,358评论 25 707
  • 时间:2017.11.20上午8:00 天气:阴,零下一摄氏度 地点:公园 人物:五个七旬老人 事件:年纪最大老人...
    胡胡丫丫阅读 146评论 0 0
  • 继续进行
    今天雨阅读 164评论 2 4
  • 昨日阅读1小时,总计253小时,第239日。 读吕思勉《两晋南北朝史》至35% 中书之职,旧掌机务。汉元以令、仆用...
    龙套哥萨克海龙阅读 404评论 0 0