我正在尝试使用Android Studio,第一次启动它时,它需要45分钟来编译……如果我不退出应用程序,这是可以的-每次后续编译/运行应用程序将花费大约45秒。

我试着检查我的一些缓存:在我的主目录中有一个。gradle/caches文件夹,它包含123 MB。

在我的项目文件夹中还有一个。gradle文件夹…其中一个任务工件大概有200mb。我很害怕随机地把它们都炸了。删除文件夹的哪些部分是安全的?

有没有更好的解释为什么我的Android工作室在第一次加载应用程序时永远运行gradle组装任务?

我也必须清除intellij缓存吗?


当前回答

清除特定项目/jar的缓存:

找到与该项目相关的所有缓存文件

find ~/.gradle/caches -name yourproject

上面的命令将返回所有与你的项目相关的缓存文件

rm -rf <each file returned>

您需要将缓存文件的路径传递给上面的命令。

gradle clean install

最后拉出最新的工件

更新:

删除缓存的一行代码:

for file in `find ~/.gradle/caches -name yourprojectartifactid`; do `rm -rf $file`; done

其他回答

我删除了grade的内容。属性(全局属性)手动。 操作完成。

将compileSdkVersion和targetSdkVersion从30升级到31,解决了我的情况下的问题。但是构建在99%时失败,给出了这个奇怪的错误,在这里发现了一个以上的文件,与操作系统独立的路径“lib/armeabi-v7a/libfbjni.so”。由给出的解求解。

这里张贴的信息似乎不正确。一些人报告了如何清除Android构建器缓存(使用任务cleanBuildCache),但似乎没有意识到所说的缓存是独立于Gradle的构建缓存AFAIK的。

我的理解是,Android的缓存早于(并启发了)Gradle,但我可能错了。Android的构建器是否会被更新为使用Gradle的缓存并退出自己的缓存,我不知道。

编辑:Android构建器缓存是过时的,已经被淘汰。Android的Gradle插件现在使用Gradle的构建缓存代替。为了控制这个缓存,你现在必须与Gradle的通用缓存基础结构进行交互。

提示:在线搜索Gradle的缓存帮助,不要提到关键字“android”,以获得当前相关缓存的帮助。

编辑2:由于下面评论中的tir38的问题,我正在使用Android Gradle插件v3.4.2项目进行测试。gradle缓存是由org.gradle启用的。在gradle.properties中缓存=true。我做了一对干净的构建和第二次大多数任务显示FROM-CACHE作为他们的状态,显示缓存正在工作。

令人惊讶的是,我有一个cleanBuildCache gradle任务和<user-home>/. Android /build-cache/3.4.2/目录,两者都暗示存在一个Android构建器缓存。

我执行cleanBuildCache, 3.4.2/目录消失了。接下来我做了另一个干净的构建:

没有任何变化:大多数任务以启用缓存的速度显示FROM-CACHE状态并完成构建。 重新创建“3.4.2/”目录。 3.4.2/目录为空(保存2个隐藏的零长度标记文件)。

结论:

所有正常的Android构建器任务的缓存是由Gradle处理的。 执行cleanBuildCache不会以任何方式清除或影响构建缓存。 那里仍然有一个Android构建器缓存。这可能是Android构建团队忘记删除的残留代码,或者它实际上缓存了一些奇怪的东西,无论出于什么原因,都没有或不能移植到Gradle缓存中。(恕我直言,“不能”选项是完全可以改进的。)

接下来,我通过删除org.gradle禁用Gradle缓存。缓存=true从gradle。属性和我尝试了一些干净的构建:

构建很慢。 所有任务都显示它们的状态为正在执行,而不是缓存或最新。 “3.4.2/”目录继续为空。

更多的结论:

当Gradle缓存命中失败时,没有Android构建器缓存回退。 Android构建器缓存,至少对于普通任务来说,确实已经被取消了。 相关的android文档包含过时的信息。特别是缓存在默认情况下并没有启用,Gradle缓存必须手动启用。

编辑3:用户tir38确认Android构建器缓存已经过时,并且已经被消除。Tir38也制造了这个问题。谢谢!

gradle守护进程还为每个构建日志创建许多大型文本文件。它们存储在这里:

~ gradle守护/ X。X /日志daemon-XXXX出局。

“X.X”是正在使用的gradle版本,比如“7.5”,而“XXXX”只是随机数,比如“1234”。"~"是你的用户$HOME文件夹。

总大小可以在短短几个月内增长到几百MB。没有办法禁用日志记录。这些文件不会自动删除,实际上也不需要保留。

但是你可以创建一个小的gradle任务来自动删除它们,并释放大量的磁盘空间:

添加到你的app/build.gradle:

android {

    buildTypes {
        ...
    }

    // Delete large build log files from ~/.gradle/daemon/X.X/daemon-XXX.out.log
    // Source 1: https://discuss.gradle.org/t/gradle-daemon-produces-a-lot-of-logs/9905
    // Source 2: https://stackoverflow.com/questions/23025433/how-to-clear-gradle-cache#51479044
    def gradle = project.getGradle()
    new File("${gradle.getGradleUserHomeDir().getAbsolutePath()}/daemon/${gradle.getGradleVersion()}").listFiles().each {
        if (it.getName().endsWith('.out.log')) {
            // println("Deleting gradle log file: $it") // Optional debug output
            it.delete()
        }
    }
}

要查看哪些文件正在被删除,您可以启用println()行,然后查看Android Studio -> View -> Tool Windows -> Build中的调试输出。然后按下该窗口上的“Toggle View”按钮,显示文本输出。

注意,Gradle Sync或任何Gradle Build都会触发文件删除。

更好的方法是自动将文件移动到回收站/回收站,或者至少先将它们复制到回收站文件夹。但我不知道该怎么做。

我的~ /。gradle/caches/ folder使用14G。

在使用以下解决方案后,它从14G下降到1.7G。

$ rm -rf ~/.gradle/caches/transforms-*

$ rm -rf ~/.gradle/caches/build-cache-*

奖金:

这个命令显示了使用的缓存空间的详细信息

$ sudo du -ah --max-depth 1 ~/.gradle/caches/ | sort -hr