Android studio报错:app:mergeDebugResources FAILED(记一次痛苦不堪的debug)

本文主要是介绍Android studio报错:app:mergeDebugResources FAILED(记一次痛苦不堪的debug),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、问题背景

最近接手了一个Android开发项目,由于之前的开发人员是用Android studio开发的,并且用的Android6.0的API,因此我之前用的eclipse就不能支持了,于是正式安装了Android studio,来体验一下google官方推荐的开发工具感觉如何。我的版本是2.2.2

2、问题描述

昨天上午,我在app中添加了一个activity并为之配了相应的布局文件,之后突然发现,应用报错了!!!!而且坑爹的Android studio没有给出任何的报错信息,只有一句话:app:mergeDebugResources FAILED。于是按照惯例,我首先去百度,一般来说,这种问题一定是大家都会遇到的,所以一般都会得到答案,但我万万没有想到,由于Android studio给出的这一句错误信息模糊不堪,而可以导致这个错误的原因有非常多,因此百度到的答案众说纷纭,没有一个能解决我的问题……但是学到了一个可以在Android studio中打印详细报错信息的方法,也算一点收获吧……

方法附上:

在命令行中进入项目的根目录,或者可以在Android studio的Terminal中直接操作也可以,然后敲入一个命令:

gradlew compileDebug --stacktrace

就可以输出较详细的信息,然后根据命令行给出的提示,还可以在后面加上-info或者-debug的选项得到更详细的信息,于是这个命令可以这样写:

gradlew compileDebug --stacktrace -info

或者:gradlew compileDebug --stacktrace -debug

但是并没有任何作用!给出的报错信息都是包中的类的错误位置,没有一句提到是我的代码的什么地方出了错,打印出的信息截图如下:



就这样整整耗费了我一整天的时间,debug没有任何进展,我带着万般无奈的心情在当天的bug还没有被解决的情况下睡觉了,盼望第二天能解决它……

3、排错过程

由于一直在想这个bug,我一晚上都没睡好,今天早早就醒了,起来继续debug,哎………………

前一天在百度的过程中,我看到一位大大在博客里写到出现这种报错一般是之前的代码哪里写错了,只要回复到之前的版本就可以了,但是我第一没有把项目推到github上,第二Android studio已经关闭过了,不可能使用Ctrl+z来恢复,不过我觉得这位大大说的还是很有道理的,因为我真的觉得没有什么导致了错误,也只能是这样了,于是我就顺着这个思路往下找,把项目中的十几个activity文件的代码逐行检查了一遍,同时把几十个layout文件也逐行检查了一遍,没有任何错误……崩溃

于是我又开始用老方法,企图从报错信息中找到一些蛛丝马迹。不过这一次我在打印出的信息中注意到了以前没有关注的细节,附图:


注意看我用红色标记的句子,它说compileDebug这个命令是模糊的,可以用后面那一大串来代替它,然后我突然反应过来,我报的错误一直提示什么resource的问题,于是我在这些候选命令里找到了红线标注的一句:compileDebugSources,本着死马当活马医的心态,我把打印报错信息的命令改成了如下这样:

gradlew compileDebugSources --stacktrace -info

然后还真的获得了一些不同的信息,附图如下:



注意我用红线标注的地方,它说我在drawable-xhdpi这个目录下少了一张图片,我很奇怪,因为程序出错的时候我根本没有动过图片,将信将疑地,我打开相关目录看了一下,方法如下:



如图,点击我用红线框起来的地方,把视图改成project,于是可以看到完整的目录结构:



找到报错信息提示的目录,我发现之前我用到的若干图片,只放在了mipmap-mdpi中而在mipmap-hdpi中没有,于是我复制了一份放到mipmap-hdpi中,再次尝试启动应用,神奇的事情发生了,程序正确运行,错误被排除了!!!!太感人了……

4、总结

这次的排错过程让我摸索出了很多东西,和大家分享一下

1、Android studio不像eclipse那样可以直接在logcat中打印错误信息,更别提错误代码的定位了

2、如果希望获得Android studio的报错信息,需要手动编译项目,方法我已经写在上面

3、排错时,首先用gradlew compileDebug --stacktrace -info来查看最基本的信息,然后根据这些信息进一步精确命令,比如在本例中我需要用compileDebugSources来获得更精确的定位

4、虽然感觉到Android studio用起来不如eclipse舒服,存在很多缺点:重量级,运行需要耗费许多计算资源、不能很好地给出错误提示,不能定位错误代码、有时候会出现一些莫名其妙的错误,但是毕竟它是google官方推荐的开发工具,并且目前对eclipse的维护已经停止,因此我们不得不将平台逐渐迁移到Android studio来,只好自己去适应这个工具的一些特点,相信我这次调错得到的一些经验对于今后的调试还是有一定帮助的

5、最后的最后,在编程的过程中,经验的指导作用还是相当重要的,因此当我们把每一次的debug当做一次积累经验的机会和学习调高的机会的话,那么debug也没有那么可怕了,甚至当排除一个奇怪的错误时还能获得很多的成就感。

这篇关于Android studio报错:app:mergeDebugResources FAILED(记一次痛苦不堪的debug)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

macOS怎么轻松更换App图标? Mac电脑图标更换指南

《macOS怎么轻松更换App图标?Mac电脑图标更换指南》想要给你的Mac电脑按照自己的喜好来更换App图标?其实非常简单,只需要两步就能搞定,下面我来详细讲解一下... 虽然 MACOS 的个性化定制选项已经「缩水」,不如早期版本那么丰富,www.chinasem.cn但我们仍然可以按照自己的喜好来更换

VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virtual disk”问题

《VMWare报错“指定的文件不是虚拟磁盘“或“Thefilespecifiedisnotavirtualdisk”问题》文章描述了如何修复VMware虚拟机中出现的“指定的文件不是虚拟... 目录VMWare报错“指定的文件不是虚拟磁盘“或“The file specified is not a virt

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

电脑多久清理一次灰尘合? 合理清理电脑上灰尘的科普文

《电脑多久清理一次灰尘合?合理清理电脑上灰尘的科普文》聊起电脑清理灰尘这个话题,我可有不少话要说,你知道吗,电脑就像个勤劳的工人,每天不停地为我们服务,但时间一长,它也会“出汗”——也就是积累灰尘,... 灰尘的堆积几乎是所有电脑用户面临的问题。无论你的房间有多干净,或者你的电脑是否安装了灰尘过滤器,灰尘都

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War