【我的Android进阶之旅】Android目录过长造成错误:Failed to crunch file abc_textfield_sea...
一、编译异常描述
一大早来开发一个新的需求,拉取了一个新的分支,然后导入Android Studio之后,编译就报错了,报错如下所示:
错误具体日志如下所示:
Information:Gradle tasks [:app:assembleDebug] Error:Failed to crunch file C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\exploded-aar\com.android.support\appcompat-v7\25.2.0\res\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png into C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\res\merged\debug\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png Error:Execution failed for task ':app:mergeDebugResources'. > Error: Failed to crunch file C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\exploded-aar\com.android.support\appcompat-v7\25.2.0\res\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png into C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\res\merged\debug\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png Information:BUILD FAILED Information:Total time: 2.682 secs Information:2 errors Information:0 warnings Information:See complete output in console
Error: Failed to crunch file C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\exploded-aar\com.android.support\appcompat-v7\25.2.0\res\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png into C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\res\merged\debug\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png :app:mergeDebugResources FAILED FAILURE: Build failed with an exception. * What went wrong: Execution failed for task ':app:mergeDebugResources'. > Error: Failed to crunch file C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\exploded-aar\com.android.support\appcompat-v7\25.2.0\res\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png into C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\res\merged\debug\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png * Try: Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. BUILD FAILED Total time: 6.359 secs Executing tasks: [:app:assembleDebug]
二、解决编译异常
上面是错误信息、编译不成功的原因是超过了最长限制。
解决方法1
在根目录下的build.gradle添加如下
buildDir = "C:/tmp/${rootProject.name}/${project.name}"
该代码的意思是指定 Project构建结果存放目录
对比如下所示:
没有添加时候的代码,
allprojects { repositories { jcenter() mavenLocal() } }
添加后的代码:
allprojects { repositories { jcenter() mavenLocal() } buildDir = "C:/tmp/${rootProject.name}/${project.name}" }
添加后编译成功,并且可以运行。
但是编译后的Android Studio画面确实如下所示:
如上图所示:app这个module貌似单独移出去了一样,感觉怪怪的。
并且在build目录下,并没有任何apk文件生成。
apk文件都生成到了之前配置的buildDir目录下去了。
buildDir = "C:/tmp/${rootProject.name}/${project.name}"
打开C盘 tem目录 ,可以看到生成的编译产物都在这里。
apk生成在 C:\tmp\NetEaseCloudeMusic\app\outputs\apk 目录下。
虽然方法1是有效的,但是还是感觉怪怪的,因此我决定使用方法2。
解决方法2
将工程挪到最外层文件夹。
重新从SVN服务器 checkout 一份该分支代码,到目录
C:\Code\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic
然后导入到Android Studio 编译,直接编译成功并且成功运行。
来对比一下,之前的目录是
C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic
目录太长了,导致编译失败
C:\Code\XTC_NetEaseCloudMusic\branches\APP_NetEaseCloudMusic_UseByAnonymous\NetEaseCloudeMusic\app\build\intermediates\exploded-aar\com.android.support\appcompat-v7\25.2.0\res\drawable-xhdpi-v4\abc_textfield_search_activated_mtrl_alpha.9.png
因为 abc_textfield_search_activated_mtrl_alpha.9.png 总共的路径名有241个字符,超过了windows规定的240个字符。有可能会提示:
Error: File path too long on windows, keep below 240 characters
下面是windows系统的文件目录限制
将文件路径缩短之后,编译成功,如下所示:
三、总结
出现该bug的最终原因还是因为文件目录太长导致的,所以推荐使用方法2,将项目目录缩短然后再导入到Android Studio 重新编译,方法1总感觉会有隐藏bug。
参考文档:
作者:欧阳鹏 欢迎转载,与人分享是进步的源泉!
转载请保留原文地址:http://blog.csdn.net/ouyang_peng/article/details/72596381如果本文对您有所帮助,欢迎您扫码下图所示的支付宝和微信支付二维码对本文进行打赏。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android studio 下的SDK Manager只显示已安装包的情况
原因是连接不上Google的更新服务器: 解决方法: 选择第三个Options: 修改Http Proxy Server:mirrors.neusoft.edu.cn Http Proxy Port: 80 选中 Others 下面的 Force htto://....选项 重启SDK Manager即可
- 下一篇
5.22成都workshop:4. 游戏日志采集与分析
场景简介 小吴负责公司的DevOps 以及 数据团队:在服务器和用户数上升后,开发花了非常多的时间在服务器查日志问题上。在支持移动入口、网页、推广渠道后,日志的来源也变得越来越多,加剧了他的困扰。除此之外,运营团队、BI团队、运维团队等对日志提出各自需求。 因此小吴需要一套快捷灵活的日志系统,来解决游戏开发中的这些需求。 实验概述(实验第四环节) 日志数据如何上云:ECS上日志采集 常用日志处理的几种模式 索引与查询 实时计算:演示云监控 (可选) 离线存储:延时OSS 存储与计算(可选) 具体步骤 准备步骤(可跳过) 实验环境已经默认安装日志收集客户端(Logtail),如需要手动配置实验环境,请参考环境准备 步骤1. 日志采集步骤 登陆日志服务控制台,开始创建配置 在“华东2区域”创建项目Project/Logstore project: workshop
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Hadoop3单机部署,实现最简伪集群