前几天遇到了一个很神奇的问题,现在想想挺神奇的,就决定记录一下。
崩溃的提示是像这样的:
java.lang.IllegalStateException: Required view 'XXX' with ID XXXXXX for field 'XXXXXX' was not found. If this view is optional add '@Nullable' (fields) or '@Optional' (methods) annotation.
对于java.lang.IllegalStateException的关键字,网上的回答基本上都是butterknife的bind的控件的类型不对,或者是setcontentView放在了bindview方法之前。当然这不是这个问题的原因。
在调试时,我还发现生成的activity_viewbinding中的id全部错乱了。因为viewbinding是在编译时生成的,因此断点什么的根本没法用来找原因。
clean,build了一下午之后,带我的资深研发师父也帮我来看了一下。他发现不止这个activity,而是整个模块的id都错乱了。事实上,我们应用了模块化,所以资深研发师父怀疑是module中其他的类出了问题。最后发现,是同模块下的R2文件导错了,引入了其他module的R2文件。
这个问题神奇的在于,这个问题以前没有爆发出来,现在才出来。理论上讲R2文件引入错误,应该一开始就应该爆出来的。关于butterknife的了解还是不够,这提醒我要更多学习各个框架,而不是只是单单关注眼前的业务需求。