转:https://www.jianshu.com/p/8569003b3fac
前言
昨天帮我们公司的同事解决一个问题, 他开始给我弄一个eclipse版本的代码,但是由于代码质量是真的不咋地,又是eclipse结构的代码, 所以我想给他的代码进行移植,导入成AS能够识别的方式进行编译,由于我对AS的IDE解决错误比较有心得,因为这样做了. 但是中途出现一个错误,这个错误是从未见过的,搜遍了全网,无论百度还是谷歌,都没有找到我的答案, 因此我把解决方案分享给大家,希望给大家遇到这种问题时,提供一个可行性的思路.
错误记录
duplicatesymbolintablewithresourcetype'id'andsymbolname' '
image.png
众所周知, 从eclipse的代码转换到AS中, 肯定会出现各种奇葩问题, 但是作为一个很久没碰eclipse的人,肯定不一定能够记得之前eclipse的坑了, 但是我有信心在AS上遇到问题可以解决,但是这一次, 我发现它完全是没有任何标记可言的,下面我把解决问题的一些想法和思路都说一下,或者能够为你们提供解决其他类似问题提供解决方案.(大家不要觉得不耐烦, 遇到问题就要细心去留意每一个可能点)
方案一: 执行run with --stacktrace
友情提示: 新版本可能不好找到出现直接执行这个的地方,大家可以试试先看方案三.那里有一些提示.
image.png
其实它完整的命令是这个gradlew --stacktrace
image.png
但是我们得到的结果是这样, 从这个错误信息来看,我们没法通过错误信息能够直观找出错误,因此,我继续尝试,运行提示出来的编译命令
image.png
方案二: 执行更详细查看错误信息的命令
其中完整命令是这样的.
gradlew --info --debug --stacktrace
我们得到的结果是这样的
image.png
方案三: 执行build命令,如下图所示
打开AS右边的侧边栏Gradle
image.png
很多新手朋友,更新AS 3.2以上的版本 ,发现方案一和方案二的命令再也找不到了.其实这个命令执行之后, 你会发现, 确实可以完全显示出来. 不信,你看下图.
image.png
从以上的错误信息看来,我们还是无法直接找出错误信息,
Duplicate symbol in table with resource type 'id' and symbol name ' '
心里真的无语了 ,为什么这个错误这么坑? TMD ,气死我了, 老子去百度,谷歌 行了吧?
结果百度谷歌一圈后, 泄气了, 完全没法解决啊,他们的方法和我都不一样,怎么办?
强迫自己冷静下来,从错误信息提示,唯一能够确定的是资源文件错了问题, 至于是哪个资源文件出错, 我们还无法确定.因为我们根据提示的错误. 我想出了一个最笨也是最有效的方法. 那就是一个个排查.
AS是在执行task ':app:processDebugResources'这个任务时,检查出错,那么我们就把app module的res文件夹下的每个文件夹进行排查.
具体操作如下:
先把所有的res文件夹下的内容全部复制到其他地方,然后把res目录下的文件夹全部删除, 然后复制每复制一个刚刚放在其他地方的某一个文件夹,粘贴到app module下的res文件夹,然后我们执行一次processDebugResources这个命令.
提示:processDebugResources这个命令在侧边栏的Gradle里面,如下图所示
找到other节点打开.png
需要执行的命令.png
每复制一个文件夹之后,就执行一次,直到出现相同的错误,就可以确定,你复制的文件夹内部有文件夹是有错误的,因此可以通过刚刚我们逐个排查的思路,用同样的方式排查.
最终,我们找到出错的结果是,因为布局文件中,在同一个布局文件中,有相同的Id 命名, 导致编译报错,这种错误在AS开发的话,肯定不会出现,因为你一写,就会报错, 真的是为写这个代码的前辈感到捉急.因此,要学习安卓开发,就要选AS,不然 ,eclipse的规范 ,可能真的不敢恭维.
最后我们总结一下,遇到AS的IDE出错,也许会出现很多种情况,一定要留心去观察, 一定要注意统一性,别以为事小,不放在心上, 后面出现的问题,可能让你束手无策.