Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources

问题背景不说了,直接进入主题。想要在一个老项目中使用dataBinding,按照文档说明在app的build.gradle中加上
dataBinding {
    enabled = true
}
后Sync项目,编译成功没毛病。但是在打包或是运行时,很遗憾,项目报错了。主要报错代码如下:
Caused by: org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:mergeDebugResources'.
……
Caused by: java.lang.NullPointerException
    at android.databinding.tool.store.LayoutFileParser.parseOriginalXml(LayoutFileParser.java:128)


于是百度一番(这里又不得不吐槽一下百度了,都匹配出什么结果啊),比较接近的搜索结果和解决方案比较典型的有:

(1) 布局xml文件中android:text="" 里面直接使用中文,建议使用android:text="@string/" 的形式;

(2) drawable 资源文件中含有不规范的.9.png;

尝试了一番,结果没有解决我的问题。于是又折腾好了久,都快要放弃了,直到看到一位大兄弟的博文,终于看见了曙光。感谢这位兄弟的指引:databinding新手 Execution failed for task ':app:compileDebugJavaWithJavac',

然后又转辗到这位朋友的博文:Android studio报错:app:mergeDebugResources FAILED(记一次痛苦不堪的debug)。

终于遇到了 app:mergeDebugResources这个一样的报错了。

这两篇博文的中心思想都是用android studio 的 debug神器:gradlew compileDebug 进行精准报错定位。在Android studio的Terminal中直接操作敲入一个命令:gradlew compileDebug --stacktrace,就可以输出较详细的信息,然后根据命令行给出的提示,还可以在后面加上-info或者-debug的选项得到更详细的信息。其中 compileDebug 又可以细分为以下更为明确的定位:

'compileDebugAidl',
'compileDebugAndroidTestAidl',
'compileDebugAndroidTestJavaWithJavac',
'compileDebugAndroidTestNdk',
'compileDebugAndroidTestRenderscript',
'compileDebugAndroidTestShaders',
'compileDebugAndroidTestSources',
'compileDebugJavaWithJavac',
'compileDebugNdk',
'compileDebugRenderscript',
'compileDebugShaders',
'compileDebugSources',
'compileDebugUnitTestJavaWithJavac',
'compileDebugUnitTestSources'.

参考上面两位兄弟的调试记录,在terminal 尝试了一番:gradlew compileDebugSources --stacktrace -info,终于定位到了报错的详细来源:line 1:0 mismatched input '?' expecting {COMMENT, SEA_WS, '<', PI}

Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources_第1张图片

Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources_第2张图片

于是又百度了一番,这回终于有点靠谱了,在stackoverflow上找到了最终原因:android studio UTF-8 BOM format 的问题,

Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources_第3张图片

知道是 UTF-8 BOM format 的问题那就好办,因为之前把项目从Eclipse转到 studio时就遇到了类似的问题,当时是用一款去除文件BOM的神器,把layout中的所有文件处理一下就OK了:

Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources_第4张图片

 

Android dataBinding的踩坑记录:运行时报错:Execution failed for task ':app:mergeDebugResources_第5张图片

折腾好久的debug终于拨云见日了。再次特别感谢以上几位前辈博文的参考指导!

你可能感兴趣的:(Android,dataBinding)