也谈DataBinding遇到的恶心的Bug,踩坑践行者。
blade555
8年前
<h3><strong>项目中遇到的一个问题,分享出来,希望大家可以不踩这个坑</strong></h3> <p>前话,公司是用Mac开发,在家里有时候会用Win加加班,公司的项目有几个使用了Databinding,在Mac上运行都是没有问题的,我推到Git上,回家拉下来,其中的一个报错了,另外的都没有问题!</p> <p>用过Databinding的同学都是知道,Databinding本身报错就是全部报错,并且不会有具体的错误,而且项目中还有Dagger2,Dagger2报错跟Databinding一个尿性报错那么多,都不是解决的依据。这一次报错,那错误直接需要拖好几页,连个重点都找不到!醉了</p> <p><strong>分析问题</strong></p> <ul> <li>公司项目本身没有错,在家里报错,问题应该不在代码层面上</li> <li>之前处理过一次utf8的问题,win下gradle 添加这么一行东西 <pre> <code class="language-java">tasks.withType(JavaCompile) { options.encoding = "UTF-8" }</code></pre> 那么这一次极有可能仍然是编码的问题,其中报错有两行比较重要的摘录出来<br> android.databinding.annotationprocessor.ProcessExpressions@65ff4c24 javax.xml.bind.UnmarshalException with linked exception:<br> Caused by: org.apache.xerces.impl.io.MalformedByteSequenceException: Invalid byte 3 of 3-byte UTF-8 sequence.</li> </ul> <p>我们遇到的坑大概率是别人踩过的坑,Google或者其他的搜索引擎,据说是IDE的一部分,于是找到了这个博客,确定了自己的猜测。</p> <p>题外话&问题原因&个人习惯</p> <p>Databinding最好的使用,通常是后台返回直接展示的数据,而实际上后台返回的数据有时候需要我们在处理一下,我的同事的方法是跟链接博客中一样,喜欢在xml里面做操作,(比如android:text='@{monthBean.onlineCount+"单"}')我自己则是喜欢在bean对象里面做处理,通过前缀为getStringXXX的方式来获取,而导致这个问题原因正是因为在xml里面做拼接的字符不能被正确的解析, 那么问题来了,另外其他的项目,同事也有在外面做处理,为什么没有报错,猜测是特定的字符不能被解析造成的。</p> <p>剩下的就是力气活,由于有段时间没有拉这个代码,积累的较多,我不能确定是什么时候造成的,只能猜测着用Git不断的切换,定位到产生的原因.</p> <p>不管怎样终于找到了,奇怪的是有的拼接没有问题有的拼接有问题,这其实是另外两个同事写的,看来同样是mac还是有些差别,anyway总算解决了可以继续写应该写的了.</p> <pre> <code class="language-java">android:text='@{monthBean.onlineCount+"单"}' 报错 android:text='@{billCheckoutInfo.runKm+ "公里"}' 不报错</code></pre> <p><strong>解决和建议</strong></p> <p>android:text='@{monthlyBeanBinding.onlineCount + @string/dan}'</p> <p>我会在跟同事核实为什么一个人的拼接没问题另一个人报错,建议是用getStringXXX的方式来拼接,那样可以避免这些问题,如果非要拼接就要用@String/XXX的方式.</p> <p>希望以后不要再遇到这样的问题,耽搁了一段时间,但是我还是喜欢win系统,总感觉文件系统就应该是win这样而不是mac那样,很不习惯.</p> <p>最后放上CC</p> <p><img src="https://simg.open-open.com/show/6633fd1ec713ce596ea9b31ff78c9690.png"></p> <p style="text-align:center">图片.png</p> <p> </p> <p>来自:http://www.jianshu.com/p/b969992cd833</p> <p> </p>