Lint在组装释放目标时发现致命错误

jes*_*uso 33 android android-studio

383/5000我有一个应用程序,当我将其更改为发布模式以将其上传到Play商店时,会给我编译错误

我试过分析 - 检查代码,我没有任何错误.

我也尝试了构建构建gradle中的编译sugest并且它没有给出错误,但是当我尝试安装apk时它给了我一个错误:"APK无法安装.错误:无法停止错误字符串"

org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:lintVitalRelease'.
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:100)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:70)
    at org.gradle.api.internal.tasks.execution.OutputDirectoryCreatingTaskExecuter.execute(OutputDirectoryCreatingTaskExecuter.java:51)
    at org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:62)
    at org.gradle.api.internal.tasks.execution.ResolveTaskOutputCachingStateExecuter.execute(ResolveTaskOutputCachingStateExecuter.java:54)
    at org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:60)
    at org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:97)
    at org.gradle.api.internal.tasks.execution.CleanupStaleOutputsExecuter.execute(CleanupStaleOutputsExecuter.java:87)
    at org.gradle.api.internal.tasks.execution.ResolveTaskArtifactStateTaskExecuter.execute(ResolveTaskArtifactStateTaskExecuter.java:52)
    at org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52)
    at org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:54)
    at org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43)
    at org.gradle.api.internal.tasks.execution.CatchExceptionTaskExecuter.execute(CatchExceptionTaskExecuter.java:34)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker$1.run(DefaultTaskGraphExecuter.java:248)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:336)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:328)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:199)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:110)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:241)
    at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:230)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$TaskExecutorWorker.processTask(DefaultTaskPlanExecutor.java:123)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$TaskExecutorWorker.access$200(DefaultTaskPlanExecutor.java:79)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$TaskExecutorWorker$1.execute(DefaultTaskPlanExecutor.java:104)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$TaskExecutorWorker$1.execute(DefaultTaskPlanExecutor.java:98)
    at org.gradle.execution.taskgraph.DefaultTaskExecutionPlan.execute(DefaultTaskExecutionPlan.java:626)
    at org.gradle.execution.taskgraph.DefaultTaskExecutionPlan.executeWithTask(DefaultTaskExecutionPlan.java:581)
    at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor$TaskExecutorWorker.run(DefaultTaskPlanExecutor.java:98)
    at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:63)
    at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:46)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:55)
    at java.lang.Thread.run(Thread.java:745)
Caused by: org.gradle.api.GradleException: Lint found fatal errors while assembling a release target.

To proceed, either fix the issues identified by lint, or modify your build script as follows:
...
android {
    lintOptions {
        checkReleaseBuilds false
        // Or, if you prefer, you can continue to check for errors in release builds,
        // but continue the build even when errors are found:
        abortOnError false
    }
}
...
    at com.android.tools.lint.gradle.LintGradleExecution.abort(LintGradleExecution.java:199)
    at com.android.tools.lint.gradle.LintGradleExecution.runLint(LintGradleExecution.java:263)
    at com.android.tools.lint.gradle.LintGradleExecution.lintSingleVariant(LintGradleExecution.java:359)
    at com.android.tools.lint.gradle.LintGradleExecution.analyze(LintGradleExecution.java:93)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.android.tools.lint.gradle.api.ReflectiveLintRunner.runLint(ReflectiveLintRunner.kt:38)
    at com.android.build.gradle.tasks.LintBaseTask.runLint(LintBaseTask.java:87)
    at com.android.build.gradle.tasks.LintPerVariantTask.lint(LintPerVariantTask.java:41)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:73)
    at org.gradle.api.internal.project.taskfactory.StandardTaskAction.doExecute(StandardTaskAction.java:46)
    at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:39)
    at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:26)
    at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:780)
    at org.gradle.api.internal.AbstractTask$TaskActionWrapper.execute(AbstractTask.java:747)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$1.run(ExecuteActionsTaskExecuter.java:121)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:336)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:328)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:199)
    at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:110)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:110)
    at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:92)
    ... 32 more
Run Code Online (Sandbox Code Playgroud)

san*_*alu 74

您可以使用" 分析">"检查代码"菜单手动运行检查.如文档所示,检查结果显示在" 检查结果"窗口中.这样您就可以查看和修复实际问题.

虽然不建议你也可以通过在Android Studio建议的build.gradle文件中添加以下代码来抑制lint警告.但请记住,这不会解决任何问题.您仍然可以从app\build\_protes\lint-results-release-fatal.html文件中查看它们,而无需使用手动检查菜单.

android {
  lintOptions {
    checkReleaseBuilds false
    // Or, if you prefer, you can continue to check for errors in release builds,
    // but continue the build even when errors are found:
    abortOnError false
  }
}
Run Code Online (Sandbox Code Playgroud)

  • 你是一个救生员.分析 - > Inspect Code是最好的工具. (14认同)
  • 同意.令人惊讶的是,即使最新的Android Studio在因为lint而失败了Build之后也没有这个链接,它只是显示一个代码片段来禁用错误.... !!!? (9认同)
  • 我的 Android Studio 中没有 `app\build\reports\` 文件夹,也许他们更改了 Arctic Fox 2020.3.1 中的路径? (5认同)
  • 没有反对你@Kirill,但这个老人喜欢牛奶。修复这个简单的 lint 规则需要多少年? (3认同)

Asa*_*hry 73

在这里,我写了一篇关于解决 Lint 发现致命错误问题的所有可能解决方案的文章。

一般可以通过以下方式解决:

Android Studio在以下链接中显示了html&xml文件中的所有构建错误。只需在浏览器中打开该文件,检查错误并修复它。

/YOUR_APPLICATION/app/build/reports/lint-results-release-fatal.html
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

样本错误

在此处输入图片说明

  • 我的 Android Studio 中没有 `app\build\reports\` 文件夹,也许他们更改了 Arctic Fox 2020.3.1 中的路径? (7认同)
  • 伟大的!!我认为这是解决它的**完美方法**。 (2认同)

Ard*_*rda 16

您可以在应用程序路径中找到详细信息

 /YOUR_APPLICATION/app/build/reports/ 
Run Code Online (Sandbox Code Playgroud)

在此文件夹中,有一个描述该错误的HTML文档。

有关更多信息,您可以访问我找到解决方案的页面。

https://dominoc925.blogspot.com/2018/08/how-to-find-cause-of-lint-error-while.html

  • 这是正确的解决方案。分析 > 检查代码生成太多条目,无法找到真正的罪魁祸首。 (5认同)
  • 感谢您的解决方案...我花了 10 个小时来一一纠正 lint 警告,最后使用您的解决方案。我得到了问题背后的确切原因。多谢 (3认同)
  • 我的 Android Studio 中没有 `app\build\reports\` 文件夹,也许他们更改了 Arctic Fox 2020.3.1 中的路径? (3认同)

Tal*_*hab 13

这对我有用

lintOptions { 
    checkReleaseBuilds false
}
Run Code Online (Sandbox Code Playgroud)

将此代码添加到 android {} 部分的 build.gradle 文件中

  • 您的答案与另一个答案相同。 (4认同)
  • 不推荐,最好使用“分析”>“检查代码”找到错误并修复它 (2认同)

小智 9

对我来说,结果文件lint-definite-release.xml位于app/build/intermediates/lint_vital_partial_results/release/out. 我正在使用 Android Studio 2020.3.1 补丁 4。


小智 5

确保在应用程序的所有 string.xml 文件中定义了所有翻译。


小智 5

对我来说,我检查了 /APPLICATION/app/build/reports 中的 xml 和 html 文件中的错误然后我修复了所有我可以修复的问题,其余的我通过将以下代码添加到我的 build.gradle 来抑制它们:

android {
    lintOptions {
        checkReleaseBuilds false
        abortOnError false
    }
}
Run Code Online (Sandbox Code Playgroud)

这阻止了 android studio 由于剩余的错误而中止构建


Reh*_*han 5

将其添加到 build.gradle(Module: AppName)

以下

android {
Run Code Online (Sandbox Code Playgroud)

这些行

lintOptions{
    checkReleaseBuilds false
}
Run Code Online (Sandbox Code Playgroud)

在这些线之上

compileSdkVersion 31
defaultConfig {
    applicationId "com.example.myapplication"
    minSdkVersion 21
    targetSdkVersion 31
    versionCode 1
    versionName "1.0"
    multiDexEnabled true
}
Run Code Online (Sandbox Code Playgroud)

}