【天天开铺子】BUG修改记

2023-10-17 04:30
文章标签 修改 bug 天天 铺子

本文主要是介绍【天天开铺子】BUG修改记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


作者:scott

【天天开铺子】主程序,没事儿就撸个小游戏!

此文背景:

修改一个bug耗时几个小时,确实解决了调试中发现的另一个隐藏问题,但实际上并未解决该bug本身。而是经过几个小时后,看过一个复现视频才知道走偏了。于是有感!(有感的时候会很多,但有时间有心思总结的次数却很少。)

 

具体经历如下:

1、收到bug,如下图:

(图片上的字有点小,看这里:店铺中员工全部派出时升级店铺会卡死)

简单的文字描述,无日志无截图无录屏无详细复现步骤。——(这是一种不良习惯)

2、根据上述描述不确定,因此找提供者确认步骤和关键信息,比如微信沟通:

3、经过多次沟通,并且有这个功能的开发者提供建议,感觉像是get到关键点:比如要把所有员工派出去再升级,似乎与店铺没关系。于是就第一个店铺开始,把人合成到可以升级的条件,这个过程刚好可以触发一个订单,只是派出去的人数不是全员。Ok,在关键地方打上断点,跟踪这个过程是怎么进行的,必要时再看数据。其中,跟到这里:

这个函数是将要派遣的员工类型和数量传递过来,因此要达到全员派出,这里的event.role是可以调试修改,比如改成event.role[5] = 6, 第一次合成可升级时刚好是6个店长; 原值是event.role[5]=4。经过这个调试,所有员工都走出去,并且出现’node of undefined’ 这样的报错,意思是某个对象不存在了,还在取上面的node属性。通常遇到很多很频繁的报错都会导致卡死。但是这一次在pc上调试时并没有卡死。于是在代码中写死上述调试代码,打包发布微信体验版测试。经测试,同样没有卡死,确实有报错。

4、至此,似乎解决了这个bug。顺带向其他同事分享、分析这个报错的原因。

截图说明修改前后对比,再分析原因:

5、再返回这个bug本身,说是要卡死,但是这边复测修改都没有,可能不是同一个问题,于是再次确认:

经过沟通,终于提供了一个视频 

看了这个视频,才恍然大悟,确实不是同一个问题。走偏了。从准备开始修改这个bug下午五点多开始,到晚上八点多,消耗的时间比较长,几个小时过去了。

6、废话少说,根据视频反馈和视屏查看的日志,均不是什么报错导致的卡死。要来账号,调试身份登录尝试同视屏相同操作复现。 

但是此时要求合成前面的员工,切换到要求的店铺还是类似要求。Ok,这种情况下是不可能正常操作去合成已达成条件的,于是断点,尝试通过修改内存值来绕过条件,如上图红色箭头:命中断点后修改this.isLevelUpEnable的值。

修改值:

可以成功绕过,于是发送相关事件后来到ui层处理:

注意红色箭头,这个是将事件拦截层显示出来,意在拦截在升级动画播放时的其他ui操作。此时要留意,这种操作若是不能顺利完成这个过程,则可能导致这个拦截层不消失而导致下层点击无响应。于是再联想到视屏中的反应,有点像。于是继续跟进下面的流程。比如什么地方将这个拦截层给隐藏的,通过本类搜索。

正好,相关接口就在附近,看样子是在各种回调之后执行隐藏事件拦截层。于是跟进函数内部看怎么实现的,很有可能回调没有被正常执行到。于是来到curShop.onShopLevelUp的实现:

仔细阅读这个函数的实现,想要外部传进来的cb被正常执行,则势必要执行_cb,如上图所示。在chrome中调试时,选中关键字,在ctrl+f 就会将相同关键字选中,即有个外框,如红色箭头处。再看具体逻辑,_cb要执行是有条件的,看箭头处的几处调用,再看视屏中反应的特点:无任何员工、顾客事件、订单派送员、广告推销员等,于是一目了然:这个_cb根本不会执行,因为条件不满足。至此,这个bug很明显了,也是一种常见bug,容易被忽视的bug,考虑不周或者测试深度不够,均容易埋藏此bug到以后某天才会被发现:外部传入回调参数,若是条件不满足时,也要根据实际情况来回调;若是外部并不特别关心这个回调结果,则可以不用调用。

为了验证分析结果,调试如图:

几处关键点都不满足,于是_cb确实没有执行。最后放开断点,如下图:

 

7、此时,并没有结束。再点击店铺升级和桌子附近区域,均无反应。此时很容易想到应该有什么地方事件被拦截了,于是去ccnode中断点,查看具体是哪个拦截了。

 最后再2064行断住,查看this的值

确实印证了上面推测事件拦截层永久显示了。

8、有了上述这些分析过程,解决起来自然好办,其实该bug是一种比较低级的错误。解决如下:

即增加执行标记,到最后发现没有一处执行,则此时也要执行_cb,这样就能正常执行外部逻辑。如图:

升级完成,终于把事件拦截层隐藏了,逻辑正常了。

9、终于,招募可以再点击了

10、至此,这个bug应该是解决了,去除所有断点多次复测均未再出现视屏中的问题。到此,可以发布版本供验收者复测。

 

写在最后,小结几点:

1、统一几个概念,概念不统一,执行人的方向可能出错。

卡死:即因为什么原因导致整个游戏任何地方点击都无响应,不管怎么操作都不响应。一般都是由于代码出错或者内存严重不足,或者某个功能消耗巨大时间开销或者死循环,或者全屏事件拦截。

卡顿:因性能问题导致游戏画面不流畅,即一顿一顿的感觉。有时可见持续性的,也有间断性的。

区域性事件拦截或点击无响应:即部分操作点击了没有反应,但是其他地方还可以正常点击。

全屏事件拦截或点任何位置都无响应:这种也可能被当做上述卡死认定。

2、强烈要求提bug时尽量详细,如复现步骤、截图或录屏、最好能提供日志;

3、改bug时要多使用断点调试、修改内存值以满足条件、及时和bug详情确认当前所做是否是越来越接近bug的结论、或者和提bug者核实步骤和结论;

4、若是经过一番工作,确实也解决了调试发现的问题,但是是否是解决了bug,这也要及时确认;

5、开发人员注意逻辑严谨性、多自测;

6、测试人员要更深入的测试,最好能根据策划需求做测试用例,再根据测试用例对照测试,而不是只是表面走玩玩就罢了;

7、在确认问题时,若条件允许尽量当面沟通,文字的含义不同人理解起来分歧较大;

8、一边解决问题,一边总结问题,不断优化工作流,达到一个目的:用最少的人力时间干出最有价值的事情。

 

——刀锋scott 2020.2.25

  • 微信引擎插件会对小游戏带来怎样的利好?

  • 字节小游戏上线攻略(续)!送源码福利

  • 我应该拿什么来拯救你,我的游戏?

  • CreatorPrimer 30篇教程汇总

  • Creator星球教程文章分类导航

  • 盘点一下Creator星球上的几大开源工具包

这篇关于【天天开铺子】BUG修改记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/222937

相关文章

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

如何在运行时修改serialVersionUID

优质博文:IT-BLOG-CN 问题 我正在使用第三方库连接到外部系统,一切运行正常,但突然出现序列化错误 java.io.InvalidClassException: com.essbase.api.base.EssException; local class incompatible: stream classdesc serialVersionUID = 90314637791991

android系统源码12 修改默认桌面壁纸--SRO方式

1、aosp12修改默认桌面壁纸 代码路径 :frameworks\base\core\res\res\drawable-nodpi 替换成自己的图片即可,不过需要覆盖所有目录下的图片。 由于是静态修改,则需要make一下,重新编译。 2、方法二Overlay方式 由于上述方法有很大缺点,修改多了之后容易遗忘自己修改哪些文件,为此我们采用另外一种方法,使用Overlay方式。

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

SW - 引入第三方dwg图纸后,修改坐标原点

文章目录 SW - 引入第三方dwg图纸后,修改坐标原点概述笔记设置图纸新原点END SW - 引入第三方dwg图纸后,修改坐标原点 概述 在solidworks中引入第三方的dwg格式图纸后,坐标原点大概率都不合适。 全图自动缩放后,引入的图纸离默认的原点位置差很多。 需要自己重新设置原点位置,才能自动缩放后,在工作区中间显示引入的图纸。 笔记 将dwg图纸拖到SW中

linux下修改系统日期与时间

cp /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

Windows11电脑上自带的画图软件修改照片大小(不裁剪尺寸的情况下)

针对一张图片,有时候上传的图片有大小限制,那么在这种情况下如何修改其大小呢,在不裁剪尺寸的情况下 步骤如下: 1.选定一张图片,右击->打开方式->画图,如下: 第二步:打开图片后,我们可以看到图片的大小为82.1kb,点击上面工具栏的“重设大小和倾斜”进行调整,如下: 第三步:修改水平和垂直的数字,此处我修改为分别都修改为50,然后保存,可以看到大小变成63.5kb,如下:

【第0007页 · 数组】数组中重复的数据(如何实现数组的原地修改)

【前言】本文以及之后的一些题解都会陆续整理到目录中,若想了解全部题解整理,请看这里: 第0007页 · 数组中重复的数据         今天,我们来看一个在实际工作中运用不多,但是对于一些算法题还是有必要的奇技淫巧——数组的原地修改。下面我们将通过两道题目来学习这种技巧。 【找到所有数组中消失的数】 给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1,

转:android ro.debuggable属性调试修改(mprop逆向)

android ro属性调试修改(mprop逆向)      大家都知道如果需要调试android 的程序,以下两个条件满足一个就行。第一是apk的配置文件内的AndroidManifest.xml的 android:debuggable=”true”,第二就是/default.prop中ro.debuggable=1。两种方式第一种通常是解包添加属性再打包,随着加壳软件以及apk校验等,容易出

修改Linux Samba配置,Windows无法访问问题解决

1.起初Linux Samba配置为public,无密码要求,后来想改成需要账号密码的形式。 在smb.conf中添加valid users = test并且执行sudo sudo smbpasswd -a test  添加test Samba账户。 重启Samba服务,sudo service smbd restart   2.使用Windows访问Samba,的确弹出了输入用户,密码,